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INTRODUCTION 


ADVANCED DIGITAL CORPORATION is proud to introduce the SUPER QUAD. 
The SUPER QUAD is a 280 based single board computer designed to be 
a bus master in an S100 bus system. The SUPER QUAD SBC has all the 


hardware needed to run a single user CP/M system or 2 user MP/M 


system with up to 4 external floppy disk drives and an external 


Centronics parallel interface printer all on one board. 
The board also runs with TURBO-DOS tm. 
The SUPER QUAD SBC contains: 


1) 
2) 
3) 
4) 
5) 
6) 


7) 
8) 


Z-80A cpu (4 MHZ) 

Floppy disk controller (up to 4 drives 8" or 5%") 
64K of dynamic memory (16K bank selectible) 

2K or 4K of shadow eprom (2716 or 2732) 

2 serial ports (Z80A SIO opt. syncronous) 


2 12 bit parallel ports, (Z80A PIO) 
one of which can be used 

for S100 vectored interrupts 

Real time interrupt clock (Z80A CTC) 
S100 extended address A16-A23 


ONE YEAR WARRANTY. 


*Note: Items 5 and 6 require external adaptation for RS-232 and 
Centronics. The adapter boards are 2 x 2" and are called 
PS NET. They hoop up to the back of the main frame with 


a DB-25 connector. 
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‘1. The Floppy Disk Controller 


The floppy disk controller can access up to four 8 inch or 5.25 
inch floppy disk drives. It can read and write IBM 3748 single 
density format and double density 128,256,512,1024 gedtetceiee 
formats. Data transfer is done by programmed 1/0 with wait and 
interrupt syncronization. 

Note : The controller cannot yeceus both 8 inch and 5.25 inch drives 
Simultaniously,The controller is switched from 8 inch to 5.25 inch 


drives by hardware jumper options. 


1.2 The 64 k Dynamic ram 

The 64 . ram array can be switched on and off in 16 k increments | 

- (G-16K, 16K-32K , 32K-48K , 48K-64K) under software control. This allows the 
CPU to access bank switchable external memory on the S160 bus. 

The memory has an access time of 20@ns. Refresh is done during 

Z86 Ml cycles and during wait and reset states. The memory can 

be accessed by an external DMA device on the S168 bus. 

Note : Any external DMA device that is using continous mode DMA 
cycles must transfer data at an average rate of 15 us per byte or 
faster when holding the DMA request line for more than 1.5 ms This is 
not a problem because most designers are smart enough to use 
byte-at-a-time ax burst transfer modes when dealing with slow DMA 
transfer rates. The ram row address is the low order address there- 
for the entire ram array is refreshed by the DMA device every 128. 


contiguous memory cycles. 


Ls3 System Monitor Eprom 


eee ee ee ee oe ee ee ee ee ee eee et em wee ee es oe ae oe 


The system monitor eprom is switched on during reset. It can be 
disabled and enabled under software control. It resides when 

énabiea at FO9O0Gh to FFFFh. It has commands that allow the user 

to load the CP/M , MP/M or other boot loaders from floppy disk. 

In addition it can be used to load , examine goto and test 

memory. When the prom is disabled. it does not use any system address 


space. 


1.4 Serial ports 

A Z80A DART be--sed.- foe the two serial ports , but 

a Z86A SIO/8 chip can be used in it's place. This allows 

asyncronous and synchronous serial data communications plus a variety 
of interrupt modes. Modem control signals are available at each 
serial connector. There are two switch selectible baud rate 
generators for baud rates of 5@ to 19.2 k baud. 

Note : The serial ports are TTL and must be connected to external 
ntwerace boards for RS232 communications. 


(PS NET/TI) 


Le Parallel ports 


A Z8@A PIO is used as the parallel port. The "A" channel of this chip 
is connected to the parallel port connector. This port has 8 bi-dir- 
ectional data lines and two hand shake lines. The "B" port can be split 
between the parallel port connector and the S109 bus vectored interrupt 
lines by jumper options. This allows the port to be used as an 
additional parallel port or interrupt controller or both. 


In the output mode the parallel ports can drive one TTL load . 


1.6 Real Time Interrupt clock 


A Z88A CTC is used for providing a real time system clock for MP/M. 
Three channels of the CTC are available to the user for strapping via 


a jumper header for synchronous baud rates or long clock times. 


La? $100 Bus Interface 

The S1@@ bus interface provides the signals necessary for an 8 bit 
bus master as described by the IEEE 696 bus specification. 

Vectored interrupt lines VI# - VI7 are supported via jumper options 
and Al6 - A23 are also Supported vis an I/O port. 


¢ 
The PAMNTON line is also implemented for the dynamic ram array. 


2. EPROM and Monitor operation 

The onboard EPROM occupies address FO@OH-FFFFH. The EPROM 
is switched on automatically during reset or power on, the 
EPROM contains SIO and FDC initialization code along with a 
simple debugger and floppy disk cold start loader. After 
the operating system is loaded the EPROM can be turned of€ 
so that the ram at address FO®GH-FFFFH can be accessed. The 
EPROM can be turned on and off at any time so that hardware 


dependent I/O routines can be called. 


Lan Eprom Enable / Disable 
Switching EPROM on : 


F033 3E4F MVI A,@1@@1111B ;RESET POWER ON JUMP 


‘ ; AND ENABLE MEMORY, EPROM ON 
F835 D316 OUT 16H ;WRITE TO CONTROL PORT 


Switching EPROM of€ : 


F@33 3E4F MVI A,811601111B ;RESET POWER ON JUMP 
; AND ENABLE MEMORY, EPROM OFF 
F435. D316 OUT 16H ;WRITE TO CONTROL PORT 


Jumper R configures the board to accept a 2716 or 2732 EPROM. 
Note : The EPROM is always addressed at F8@@H and can not 

be moved. Since the 2716 EPROM is 2K long it appears 

twice , F8@GH-FC@@H and FBFFH-FEFFH. 

2«2 Monier Signon 


The EPROM contains a simple debugger. 
The monitor signs on with : 


> ADVANCED DIGITAL CORP. 
Monitor Version 1.1 
Mar - 1982 |. 
Press "H" for help 


23 Monitor Commands 


The monitor commands are : 


Control B = Load disk boot loader 5.25" 


Control C 


Load disk boot loader 8". 


D SSSS QQQQ Dump memory in hex from SSSS to QQQQ 


il 


F SSSS QQQQ BB Fill memory from SSSS to QQQQ with BB 
G AAAA | = Go to address AAAA 


L AAAA = Load memory starting at AAAA 


M SSSS QQQQ DD Move from S to Q to ADDR DD 


PB SSSS Q000 Print in ascii from SSSS to Q000 
T = Test Memory 


ESC will terminate any command 


The cold boot loader will select and home drive @. 

Track @ sector 1 will be read into memory at location 8. 
Single density is assumed for track 6. 

If an error occures an error code will be printed. 

The error code must be translated using the table 

in appendex F page F-4 fig 2. 


e.g. FDC COLD BOOT ERROR 86= DISK NOT DETECTED 
FDC COLD BOOT ERROR 18= WRONG FORMAT OR NO DATA ON DISK OR BAD PHASE LOC 


LOOP. 
2.4 Cold Boot Program 
_ ; READ TRACK O SECTOR 1 INTO MEMORY 
BOOT 5: MVI A, 08H . 
OUT WAIT set double for 5 inch 
BOOT: | 
F4B5 3E6D MVI A,@DH ; RESET FDC 
F4B7 D30C OUT FDC ; ISSUE COMMAND 
FABO 0G NOP 
FDCWL: 
F4BA DBOC - IN FDC ; CHECK BUSY 
FA4BC OF RRC 
FABD DABAF4 IC FDCWl 
FACO @@ NOP ; 


KILL TIME 


F4C1 
F4C2 


F4C3 


F4C4 
F4C6 
F4C8 


F4C9 
F ACB 


FACC 
FACE 
F4D®O 


F4D3 
FAD4 
F4D5 
F4D6 
F4D7 
F4D9 
F4DB 
F4DD 


FADE 
FAE® 
F4E1 
F4E4 
FAE6 
F4E7 
F4E8 


F4EB 
F4ED 
FAEE 
F4F] 
FA4F2 
F4F5 
FAFS8 
FAF9 


0) 
a) 


hy 


3E83 


D30C 


06 


DB14 
66 


TKO: 


DB6C 


E664 


CACCF4 


FDCRD: 


DBOF 


BOOTDN: 


CD21F1 


L,A 
H,A 

A 
FDCSEC 
A,98CH 
FDC 


WAIT 

A 
BOOTDN 
FDCDATA 
M,A 

H 

FDCRD 


FDC 

A 

i) 

PSW 
H,BTERR 
MSG 

PSW 
THXB 


me we 


we we 


=e me 


me me WO 


me me MO we BO we 


ws mse WOH we BQ me WO we 


GET A RESTORE 
ISSUE COMMAND 


WAIT FOR 
INTRQ 


CHECK TRACK 6 


POINT AT LOC 6 


SET SECTOR 
GET READ COMMAND 
ISSUE COMMAND 


WAIT FOR INTRQ 
OR DRQ 

EXIT IF INTRQ 

GET DATA 

STORE 

POINT NEXT 


CHECK STATUS 
@ = NO ERROR 
OK, GO 

SAVE ERROR 
PRINT 

DISK ERROR 
GET ERROR 
PRINT IT 


INPUT / OUTPUT PORT ASSIGMENTS 


Address Function 

66 Read/write SIO Channel A Data port 

61 Read/Write SIO Channel A Status/Control Port 
G2 Read/write SIO Channel B Data port 

83 Read/Write SIO Channel B Status/Control Port 
G4 Read/Write PIO Channel A Data port 

05 Read/Write P10 Channel B Data port 

G6 write PIO Channel A Control port 

67 Write PIO Channel B Control Port 

88 Read/Write CTC Channel 6 Control Port 

§9 Read/write CTC Channel 1 Control Portol 

OA Read/Write CTC Channel 2 Control Port 

@B Read/write CTC Channel 3 Control Port 

OC Read/write FDC Command/States Port 

BD Read/write FDC Track Register 

OE Read/Write FDC Sector Register 

OF Read/write FDC Data Port 

16 Unused 

ll Unused 

12 | Unused 

13 Unused 

14 Read/Write FDC Syncronization/Drive/Density 
Ls Write S16@ Buss Extended Address A16-A24 
16 ' Write On-Board Memory Control Port 

17 Unused 

18 Unused 

19 Unused 

lA Unused 

1B Unused 

LC Unused 

1D Unused 

1E . Unused 

1F Unused 


All addresses are listed in Hexidecimal. 
The unused input / output ports are internally decoded and 


should not be used by external S16@ 1/0 boards. 
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4.4 


This 


S16@ Vedtored Interrupt lines or to connector J2 (see sec 6.6 ) 


4.5 


4.6 


INPUT / OUTPUT PORT DISCRIPTIONS 


Serial Communications Port A --- See 
60 Read/Write SIO Channel 

61 Read/write SIO Channel 
Serial Communications Port B --- See 
62 Read/write SIO Channel 

93 Reaag/write SIO Channe]) 
Paralled Interface Port A --- See 
64 Read/Write PIO Channel 

06 Write PIO Channel 

. Parallel Interface Port B --- See 


Appendex A 
A Data por 


A Status/Control Port 


Appendex A 


B Data por 
B Stutus/C 


Appendix B 


A Data por 
A Control 


Appenaix B 


t 


t., 


ontrol Port 


t 
Port 


port can be jumpered via jumpers E through P to the 


65 Read/wr ite PIO Channel B Data port | 
(7 Write PIO Channel B Control Port 
Control Timmer Interrupt circuit --- See Appendix C 
08 Read/Write crc Channel © Control Port 
09 Read/Write CTC Channel 1 Control Port 
BA Read/Write crc Channel 2 Control Port 
0B Read/Write CTC Channel 3 Control Port 
Floppy Disk Controller cloner! See Appendix D 
QC Read/Write FDC Command/States Port 
8D Read/Write FDC Track Register 
BE Read/write FDC Sector Register 
OF Read/Write FDC Data Port 


li 


4.7 
14 


Port Read : 
cc 


Floppy Disk Control Port 
Read/Write 


FDC Syncronization/Drive/Density 


When the cpu reads this port the cpu is placed into a wait 


State until a data byte can be transfered to or from the floppy 


disk controller or untill the command complete/terminate status 


(INTRQ) 


is set by the floppy disk controller. The floppy disk 


controller INTRQ status bit is placed on the data bus as bit D7. 


This bit can be tested to determine if data is to be transfered 


of if the 
fone f—---- 4 -- + - 
1 D7 ! D6 ! D5 ! 
$-—--4+----4+----4- 
' ! { 
! ! ! 
\ ! ! 
! ! ! 
! ' 4 
y ! ! 
1 ! ee 
! pineal 
lhe ce ce eee ee a we 


Port Write ; 
The low two bits 


selected. 


D1 D@ 
8 1) 
4) 1 
1 Y) 
1 1 


command is complete. 


D7 = MSB, 


care 
care 
care 
care 
care 
care 
care 
G=active, 


Don't 


l=inactive 


D@ and Dl of this port control which drive is 


Disk drive @ selected 
Disk drive 1 selected 
Disk drive 2 selected 
Disk drive 3 selected 
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Bit D3 sets the density mode. When bit D3 = @, single density is 


selected. When bit D3 = 1, double density is selected. 


en ee ee om, oe ee 
! D7 ! D6 ! D5 ! D4! D3 ! D2! Di ! DO! D7 = MSB, D@ = LSB 
$e nn fa a fn ee a fp et tt 
! ! ! ! ! ! ! ! 
! ! ! } ! ! ! +-- Disk drive select bit D@ 
! ! ! ! ! ! 4+------- Disk drive select bit Dl 
! } ' ! ! aa Sate Se See SIDE SELECT, ®O=HEAD @,1=HEAD 1 
! ! ! ! fee mn nn nn nee Density, @=single, l=double 
! ! ! ten nr ne Don't care 
! ! te nnn nr ern eee Don't care 
! tm So eeieateniontententestentetertestententententetestentententententented Don't care 
tee ea a a ree Don't care 


4.8 Extended address port --- See Section 8.1. (buss defination) 


15 Write S106 Buss Extended Address A16-A23 
Port Write : ; 


--+ 


-—-_ —_— 2 a oe — = a oe 


0 
oN 
+n + 
we, 
un 
‘S) 
> 
+m + 
0 
J 
e, 
NO 
+m + 
0 
~~ 
ey) 
re) 


is port controls the S10@ Extended address lines. 


= MSB, 


DO 


LSB 


q- em pee tm ome 0m cee Om cen 


3 


4.9 On-Board Memory Control Port 
16 Write On-Board Memory Control Port 


This port controls the onboard memory managment circuit, 

Prom enable and disable and power on jump reset eivcuies: 

Port write : 

The four low order bits D@#,D1,D2 and D3 switch the ee ee memory 
in 16k banks corresponding to address @OOGh-3FFFh,400G0H-7FFFH, 
8000H-BFFFH and COOO-FFFEH on and off. When a particular bank is 
switched off, external S108 memory can be accessed in that 

banks address range. This feature allows external memory to be 
added to the system for mudeaanser operating systems. 

Bit DS of this port switches the on-board EPROM on and off. 

The onboard EPROM occupies address FOOOH-FFFFH. The EPROM 

is switched on automatically during reset or power on, the 
EPROM contains SIO and FDC initialization code along with a 
simple debugger and floppy disk cold start loader. After 

the operating system is loaded the EPROM can be turned off 

so that the ram at address FOOOH-FEFFA can be accessed. 

Bit D6 reset the power on jump circuit. Bit D6 must be set 

high after a reset or power on situation before ram can 


be accessed, 


DO ! D7 = MSB, D@ = LSB 


! ! l=bank on, @=bank off 

! +-- Memory Bank @@0@H-3FFFH 

tonne -- Memory Bank 4@@0@H-7FFFH 

essa Memory Bank 8@9@0H-BFFFH 
Lesa SSS oS SSS ee Ses Menory Bank CO@@H-FEFFFR 

aaa aaa a Don't care 

SSS nS SSS eae SSeS PROM enable=0, Disable=1] 
Tee a re ae ee Power on jump reset=1 

wo ree Don't care 


om Oo gan Ot ¢cs 6 Ose Oe 
0 on 0 gan O08 gae Oc 


+ 
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5.8 Jumper Definitions 


Jumper Function 

A CPU clock rate 2mhz/4mhz 

B External/Enternal Tx/Rx clock for SIO channel A 

C External/Enternal Tx/RxX clock for SIO channel B 

D Eight inch - five inch Drive selection 

E Select S168 interrupt vector line V1I@ OR PINT. 

P Select $160 interrupt vector VIO/PINT or Parallel 


Port B bit D® on J2-25. 

N Select S10@ interrupt vector VI1 or Parallel 
Port B bit Dl on J2-27. 

M Select. S198 interrupt vector VI2 or Parallel 
Port B bit D2 on J2-29. 

K Select S160 interrupt vector V13 or Parallel 
Port B bit D3 on J2-31. 

J Select S10@ interrupt vector V14 or Parallel 
Port B bit D4 on J2-33. 


H Select S160 intcrrupt vector VI5 or Parallel 
Port B bit D5 on J2-35. 
G Select S108 interrupt vector VI5 or Parallel 
Port B bit D6 on J2-37. 
F Select S100 interrupt vector VI7 or Parallel 
Port B bit D7 on J2-39. 
R Select 2716 or 2732 EPROM. 
S Define floppy disk connector for eight ad five inch 
drives, 
T Enable / Disable S196 bus memory write signal on 
Jl - 68 
6 8 Jumper Descriptions 
6.1 A CPU clock rate 2mhz/4mhz 


This jumper determines the cpu clock rate. 
The jumper is located below IC U7. 


fo—— 4-4 -4---+ 
Yet 2 ts A 
t-——+—---+---+ 


Install Plug between pusts 1 & 2 for 4mhz operation. 


Install Plug between posts 2 & 3 for 2mhz operation. 


6.2 B External/internal Tx/Rx clock for SIO channel A 
Jumper B connects the SIO channel A to either the internal baud rate 


ae . ; 
generator or to the connector JA pin 9 for use in sycronous applications.- 
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Jumper B is located near J5. 


+---+ 
!i1it Connector J5 pin 9 
+-~--+ 
|: 2! SIO TX/RX clock input 
+---+ 
Pasi Baud rate generator channe] A 
+---+ 


aeeart Plug between posts 1 & 2 for external SIO crock, 


Install Plug between posts 2 & 3 for Baud rate generator. 


6.3 C External/internal Tx/Rx clock for SIO channel B 
Jumper C connects the SIO channel B to either the internal baud rate 
generator or to connector J5 pin 9 for use in sycronous applications. 


Jumper C is located near J5. 


+---+ 
1! Connector J5 pin 9 
+---+ | 
[: 2 ! SIO Tx/Rx clock input 
f-—-——+ 
a oe Baud rate generator channel B 
+---+ 


Install Plug between posts 1 & 2 for external SIO clock. 


Install Plug between posts 2 & 3 for Baud rate generator. 


6.4 D Eight inch z five inch Drive selection 


Jumper D is located near IC U2. 


+---+ 
[3 6 ! 8 inch floppy clock source 
+--—-+ 
ee FDC clock input 
+---+ 
! 4 ! 5.25 inch floppy clock source 
+---+ 
L348 5.25 head load/motor 
+---+ 
ee | Head load source 
[ Heer 
ae ee 8 inch head load 
+---+ 


Install Plug between posts 1 & 2 and 5 & 6 for 8 drives. 


Install Plug between posts 2 & 3 and 4 & 5 for 5.25 inch drives. 
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Note : There are other board modifications needed to interface 
the FDC to a 5.25 inch drive. 

6.5 E Select S190 interrupt vector line VI@ OR PINT. 
Jumper E selects the interrupt line to be ees when channel B 

bit D@ is programmed for interrupts. 


Jumper E is located below IC U8. 


+ 
! 
+---+---4---+ 
Install Plug between posts 1 & 2 for VI® interrupt pin. (J1-4) 


Install Plug between posts 2 & 3 for PINT interrupt pin. (J1-73) 
6.6 ae Select S108 interrupt vector VIO/PINT or Parallel 
Port B. bit D@ on J2-25. 


This jumper is located near connector J2. 


Install Plug between posts 1 & 2 to connect the PIO bit D@# 

to J2 pin 25 (when the PIO bit is programmed for input/output). 
Install Plug between posts 2 & 3 to connect the PIO bit D@ 

to the jumper selector area E, VI®/PINT (when the PIO bit is 
programmed for interrupt mode). 

6.7 NG Select 5100 interrupt vector V1ll or Parallel 


Port B- bit Dl on J2-27. 
This jumper is located near connector J2. 


$---4+-/—F4-- + 
ee eae ee 
a es 


Install Plug between posts 1 & 2 to connect the PIO bit Dl 

to J2 pin 25 (when the PIO bit is programmed for input/output). 
Install Plug between posts 2 & 3 to connect the PIO bit Dl 

to the vectored interrupt line VI1l (when the PIO bit is 


programmed for interrupt mode). 
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6.8 MH Select S160 interrupt vector V12 or Parallel 


Port B bit D2 on J2-29. 


This jumper is located near connector J2. 
} $—-—--4--Hf$a1-4 


db 2 ft 
4+—--—-+-—-+---4+ 
Install Plug between posts 1 & 2 to connect the PIO bit D2 


to J2 pin 25 (when the PIO bit is programmed for input/output). 


Install Plug between posts 2 & 3 to connect the PIO bit D2 
to the vectored interrupt line VI2 (when the PIO bit is 
programmed for interrupt mode). 
6.9 KS Select S166 interrupt vector VI3 or Parallel 
Port B bit D3 on J2-31. 

This jumper is located near_connector J2. 

Se ee ee 

td 2 Ss 
Install Plug between posts 1 & 2 to connect the PIO bit D3 


to J2 pin 25 (when the PIO bit is programmed for input/output). 


Install Plug between posts 2 & 3 to connect the PIO bit D3 
to the vectored interrupt line VI3 (when the PIO bit is 
programmed for interrupt mode). 
6.18 oi Select S100 interrupt vector VI14 or Parallel 
Port B bit DA on J2-33. 

This jumper is located near connector J2. 

Penn petofebey 

Dd dy ogo Be 

4---+---+---+ 
Install Plug between posts 1 & 2 to connect the PIO bit D4 
to J2 pin 25 (when the PIO bit is programmed for input/output). 
Install Plug between posts 2 & 3 to connect the PIO bit D4 
to the vectored interrupt linr VI4 (when the PIO bit is 
programmed for interrupt mode). 


6.11 KM Select S160 interrupt vector VI5 or Parallel 
Port B bit D5 on J2-35. 
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This Jumper is located near connector J2. 


Install Plug between posts & 2 to connect the PIO bit D5 
to J2 pin 25 (when the P1O bit is programmed for input/output). 


Install Plug between posts 2 & 3 to connect the PIO bit D5 
to the vectored interrupt line V15 (when the PIO bit is 
programmed for interrupt mode). 

O%L2 BN Select S16@ interrupt vector VI6 or Parallel 


Port B bit D6 on J2-37. 


This jumper is located nmear_connector J2. 
ip cre Pies ee 


Me oD ody 2, A 
4+—---+-~--+---4+ 
Install Plug between posts 1 & 2 to connect the PIO bit D6 
to J2 pin 25 (when the PIO bit is programmed for input/output). 
Install Plug between posts 2 & 3 to connect the PIO bit D6 
to the vectored interrupt line VI6 (when the PIO bit is 


programmed for interrupt mode). 


6.13 P Select S100 interrupt vector VI7 or Parallel 
Port B bit D7 on J2-39. 


This jumper is located near_connector J2. 
r~ ‘ 
bennett nat 
Install Plug between posts 1 & 2 to connect the P10 bit D7 


to J2 pin 25 (when the PIO bit is programmed for input/output). 


Install Plug between posts 2 & 3 to connect the PIO bit D7 
to the vectored interrupt line VI7 (when the P10 bit is 


programmed for interrupt mode). 


6.14 R Select 2716 or 2732 EPROM. 


19 


Jumper R configures the board to accept a 2716 or 2732 EPROM, 


Jumper R is located near the Z8@ chip. 


+———+ 
Lok Address line All 
+--=+ 
12! EPROM input 
a bones 
as as +5 volts 
+---+ 


Install Plug between posts 1 & 2 for a 2732 EPROM. 

Install Plug between posts 2 & 3 for a 2716 EPROM. 

Note : The EPROM is always addressed at F89@H and can not 

be moved. Since the 2716 EPROM is 2K long it appears 

twice , E86OH-FC@@H and FBFFH-FFFFH. 

6.15 S Define floppy disk connector for eight , five inch 
drives and FDC chip type. 


This jumper is located U26.  f— | 
+ 


Prig? at it 
4+—---+---+4+---+ 
For 8" set-up plug the following jumpers: 
1to4,2to3,5to6,7to8s. 


For 5 1/4" plug the following jumpers: 


lto2,5to08,6to9,7tol@,lltol2.(see factory installed jumpers’ for 
additional jumpers or changes.) 
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6.16 T Enable / Disable S186 bus memory write signal on 
Jl - 68 
This jumper is located near U18. 


Install Plug between posts 1 & 2 to connect the memory write 
Signal (MEMWR) to the S108 bus pin 68. 


7.0 Baud Rate Switch 


The baud rate of the two serial channels can be select separately 
by setting the baud rate switch. The baud rate Switch is an 8 
pole switch located near U54. It is split into two sections. 
Switches 1,2,3,4 set the baud rate for the SIO channel B and 


switches 5,6,7,8 set the baud rate for the SIO channel A. 


fea a Se ee + OFF (up) 
SWl Pre PG ake Be hs de i oe ge, Ls ct 
teeta nee Hee e See see S ee ese == + ON (down) 


<- Channel B -> <- Channel A -> 
7.1 Baud rate switch setting 


Switch 8 | 6 5 Channel B baud rate 
Switch 4 3 2 1 Channel A baud rate 


OP ee ee Se eee eee ee ee ete ee me ee mee me em cee 8 ee ee me cee eee ee ee ee eee eee eee ee ee eee ee ee gee ee ee ee es ee ee ee ee ee ees eee oe 


on on on on 5@ 
off on on on 75 

on off on on 116 
off off on on 134.5 
on on off on 156 
oLft on-off on 30@ 
on off off on 608 
off off off on 1280 
on on on off 1806 
off on on off 260@ 
on off on off 2420 
off off on off 3600 
on on off of f 4806 
off on off of€ 720@ 
on off off off 9666 
off off of £ off 19,200 


For exact baud rate frequencies see Appendix D 


2) 


8. External Connector Pin definitions 


et ee eee ee ce ee cee ee em oem cm em mee eae em cue ee em cD ee ee ee ee ee ee ee ee ae ee ee ae oe ee ee 


PIN# NAME PIN ¢# 
l +8V 51 

2 +16V 52 

3 XRDY 53 

4 VIG* 54 

5 V1I1* 55-57 
6 VI2* 58 

7 ViI3* 59 

8 ViI4* 60 

9 VI5* 61-64 
1@ VI6* 65,65 
Ta VI74 67 

12 NM1I* 68 

LS PWRFAIL* 69 

14 DMA3* 7B 

15 Al8 71 

16 Al7 72 

17 Al6 73 

18 SDSB* 74 

19 CDSB* 75 

20 GND 76 

21 NDEF TT 

22 ADSB* 78 

23 DODSB* 79-87 
24 G 88-95 
25 PSTVAL* 96 
26 PHLDA 97 
27,28 RFU 98 
29-34 A5 ,A4,A3,A15,A12,A9 
35 DOL/DATA 1 99 

36 DOG/DATA @ 168 
37 Al@ 

38 DO4 

39 DOS 
~—4G-43 DO6 ,DI2,D13,D17 

44 SMI 

45 souT 

46 SINP 

47 SMEMR 

48 SHLTA 

49 CLOCK 

56 GND 
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GND 
SLAVE CLR* 
DMAO* —DMA2* 
SXTRQ* 
Alg 
SIXTN* 
A26-A23 
NDEF 
PHANTOM* 
MWRT 

RFU 

GND 

RFU 

RDY 

INT* 
HOLD# 
RESET* 
PSYNCH 
PWR* 
PDBIN 
A@-All 
DO2-D16 
SINTA 
SWO* 
ERROR* 


POC* 
GND 


8.2 Connector J2 - Parallel port connector 


1 ARDY PIO Channel A ready signal 
2 ARDY RET ground 
3 ASTRB* PIO Channel A strobe 
4 ASTRB RET ground 
5 PAG PIO Channel A data bit D@ 
6 PA® RET ground 
7 PAL PIO Channel A data bit Dl 
8 PA] RET ground 
9 PA2 PIO Channel A data bit D2 
16 PA2 RET ground 
11 PA3 PIO Channel A data bit D3 
12 PA3 RET ground 
13 PA4 PIO Channel A data bit D4 
14 PA4 RET ground 
15 PAS PIO Channel A data bit D5 
16 PAS RET ground 
uj PA6 PIO Channel A data bit D6 
18 PA6 RET ground 
19 PA7 PIO Channel A data bit D7 
20 PA7 RET ground 
21 BRDY PIO Channel B ready signal 
22 BRDY RET ground 
23 BSTRB* P10 Channel B Strobe 

| 24 BSTRB RET ground 

* 25 PBO ; PIO Channel B data bit D@ 
26 PB@® RET ground 

S 27 PBl PIO Channel B data bit Dl 
28 PB1l RET ground 

x 29 PB2 PIO Channel B data bit D2 
390 PB2 RET ground 

* 31 PB3 PIO Channel B data bit D3 
32 PB3 RET ground 

= 33 PB4 PIO Channel B data bit D4 

34 PB4 RET ground 

> 35 PB5 PIO Channel B data bit D5 
36 PB5 RET ground 

* 37 PB6 P1O Channel B data bit D6 
38 PB6 RET ground 

* 39 PB7 PIO Channel B data bit D7 
4 + 5 VOLTS 


* Note : These pins can can be jumpered to the S188 bus 


vectored interrupt lines. 


8.3 Connector J3 Floppy disk connector 


8 inch 5.25 inch 


iL ground 

2 Alternate Head 2* 
3 ground 

4 N/C 

5 ground 

6 N/C 

7 ground 

8 N/C 

9 ground 

1@ N/C 

ll ground 

12 N/C 

13 ground 

14 Head 2% 

LO | ground 

16 N/C 

17 1 ground 

18 2 Head load* 

19 3 ground 

20 4 Index* 

21 5 ground 

22 6 Ready* 

23 a ground 

24 8. Above Track 43% 
25 9 ground 

26 16 Drive select g* 
27 14, ground 

28 12 Drive select 1* 
29 13 ground 

30 14 Drive select 2* 
31 15 ground 

32 16 Drive select 3% 
33 17 . ground 

34 18 Direction 

35 19 : ground 

36 26 Step* 

37 21 ground 

38 22 Write Data* 

39 23 ground 

40 24 Write gate* 

4) 25 ground 

42 26 Track @* 

43 27 ground 

44 28 Write protect* 
45 29 ground 

46 38 Read data* 

A7 31 ground 

48 32 Motor on* 

49 33 ground 

56 34 | N/C 
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4 Connector J4 - Serial port Channel A 


1 N/C 
2 DCDA* Data Carrer Detect Channel A * 
3 SYNCA* Sync Detect 
4 RxXDA Receive data 
5 CTSA* Clear to send 
6 TXDA Transmit data 
7 RTSA* Request to send 
8 DTRA* Data terminal ready 
9 Tx /RXCA* Transmitt / receive clock 
1@ GND 
ll N/C 
12 +16 VOLTS 
13 -16 VOLTS 
14 +5 VOLTS 
8.6.5 Connector J5 = Serial port Channel B 
1] N/C : 
2 DCDA* Data Carrer Detect Channel A * 
S SYNCA* Syne Detect 
4 RxDA Receive data 
5 CTSA* | Clear to send 
6 TXDA Transmit data 
7 RTSA* Request to send 
8 DTRA* Data terminal ready 
9 Tx /RXCA* Transmitt / receive clock 
16 GND 
mt N/C 
12 | +16 VOLTS 
13 -16 VOLTS 
14 +5 VOLTS 
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S186 BUS 
$------------------------------------------- - -- -- -- == = + 
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16.1 


Factory Installed Jumpers 


em ee ee wee ee ee ws ee em ee em ee ee ee ee ee ee ee oe es om 


Jumper 

A 1-2 CPU clock 4mhz 

B 2-3 Tx/Rx clock for SIO A internal 

C 2-3 Tx/RX Clock for SIO B internal 

D 1-2 ,5-6 Eight inch Drive selection 

E 1-2 Select vector line VI6 

F 2-3 Parallel Port B bit D@ on J2-25. 
G 2-3 Parallel Port B bit Dl on J2-27. 
H 2-3 Parallel Port B bit D2 on J2-29. 
J 2-3 Parallel Port B bit D3 on J2-31. 
K 222 Parallel Port B bit D4 on J2-33. 
M 2-3 Parallel Port B bit D5 on J2-35. 
N 2-3 Parallel Port B bit D6 on J2-37. 
P 2-3 Parallel Port B bit D7 on J2-39. 
R 2-3 Select 2716 

S 1,4;2,3;5,6;7,8 define floppy disk connector 

J I-Z Enable S189 bus memory write signal 
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16.2 


Factory Installed jumpers for 5.25 inch floppy option 


line VI@ 


B 


B 
B 
B 
B 
B 
B 
B 


Jumper 

A 2-3 CPU clock 4mhz 
B 2-3 

Cc 2-3 

D 1-2,5-6 

E 1-2 Select vector 
F 2-3 Parallel Port 
G 2-3 Parallel Port 
H 2-3 Parallel Port 
J 2-3 Parallel Port 
K 2-3 Parallel Port 
M 2-3 Parallel Port 
N 2-3 Parallel Port 
P 2-3 Parallel Port 
R 2-1 Select 2716 

S 1,23;5,8:6,9;7,18;11,12 Define floppy 


a 


(to convert an 8" board to 5 1/4" 
tion to the addendum) 


Capacitor C22 is changed to a 10@pf or parallel.a 47p£ with 


the following is required 


Capacitor C6 is changed to a 1@6mf. 


Resistor R4 is changed to 226k 


ohm 


i- 3 Enable $168 bus 


bit 
bit 
bit 
bit 
bit 
bit 
bit 
bit 


D@ 


on 
on 
on 
or) 
on 
on 
on 
on 


Tx/Rx clock for SIO A internal 
Tx/Rx clock for SIO B internal 
Eight inch Drive selection 


S222 % 
JI2=-27%. 
J2-29. 
J2-31. 
J2-33 
J2=35% 
IZ 3:1 
J2-39. 


disk connector 
memory write signal 


Re-adjust the phase lock loop by adjusting the R26 pot. 
An easy way to adjust would be to put one trace of the scope on 
pin 7 of the u27(74s124) and the other channel on a 2 MHZ. 
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in addi- 


i a 


16.3 


Remove all jumpers on the disk drive. Install jumpers as follows: 


10.4 


16.6 


Shugart SA 80@ Jumpers 


ce ee ee met eee me we eee nee ee ee ee eet ee ee em eee ee ee oe eee 


Disk drive jumpers 


Jumper 
Jumper 
Jumper 
Jumper 
Jumper 
Jumper 
Jumper 
Jumper 
Jumper 


DS 


Shugart 856 


— om on ow ae 


Jumper 
Jumper 
Jumper 
Jumper 
Jumper 
Jumper 
Jumper 
Jumper 
Jumper 
Jumper 
Jumper 
Jumper 
Jumper 
Jumper 
Jumper 
Jumper 


M 
FM,MFM 


DSl1 for drive 1 and DS2 for drive 2 


install termination at the end of cable. 


MEE 


Model 78@ 


Disk drive jumpers 


Install jumpers as follows: 


Jumper 
Jumper 
Jumper 
Jumper 
Jumper 
Jumper 


Jumper 
Jumper 
Jumper 
Jumper 
Jumper 
Jumper 


J1-4,J31-8 
J1¢d 

J7 

ost! 

SE2 
J11,HS1 
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16.7 TANDON SLIM LINE 
Disk drive jumpers 
Install jumpers as follows: 


DS1 OR DS2 
INSTALL THE TERMINATION RES. AT THE END OF THE CABLE 


16.8 NEC model FD116@ 
Disk drive Jumpers 


Install jumpers as follows: 


Jumper C Jumper PRI 
Jumper N Jumper DLD 
Jumper HLS Jumper FU 
Jumper M 

10.9 QUME data track 8 


Disk drive jumpers 
Install jumpers as follows: 


DS1 OR DS2 
CUT X 
CUT Z 
CUT tL 
INSTALL Y 
INSTALL C 


10.9.1 TANDON 5 1/4 " DRIVE(48TP1L) 
Disk drive jumpers 
Install jumpers as follows: 


On the dip shunt header only pin2,7,8 are on. 
for DS1 and pins3,7,8 for DS2. 
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11.8 Appendex & Data sheets 
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1 ies ee | Appendex A = Z8OA SIO / DART cecoeeoereeveee e@ 
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28470 280° DART 
Dual Asynchronous 
Receiver/Transmiltter 


Product 
Specification 


March 1981 


Features 


@ Two independent full-duplex channels with 


separate modem controls. Modem status can 


be monitored. 


@ Receiver data registers are quadruply buf- 
fered; the transmitter is doubly buffered. 


Interrupt features include a programmable 
interrupt vector, a “status affects vector” 
mode for fast interrupt processing, and the 
standard Z-80 peripheral daisy-chain inter- 
rupt structure that provides automatic inter- 
rupt vectoring with no external logic. 


w In xl clock mode, data rates are 0 to 500K 
bits/second with a 2.5 MHz clock, or 0 to 
800K bits/second with a 4.0 MHz clock. 


f Programmable options include 1, 1% or 2 
stop bits; even, odd or no parity; and xl, 
x16, x32 and x64 clock modes. 


@ Break generation and detection as well as 
parity-, overrun- and framing-error detec- 
tion are available. 


Description 


The Z-80 DART (Dual-Channel Asynchro- 
nous Receiver/Transmitter) is a dual-channel 
multi-function peripheral component that 
satisfies a wide variety of asynchronous serial 
data communications requirements in micro- 
computer systems. The Z-80 DART is used as a 
serial-to-parallel, parallel-to-serial converter/ 
controller in asynchronous applications. In 
addition, the device also provides modem con- 
trols for both channels. In applications where 


modem controls are not needed, these lines 
can be used for general-purpose I/O. 

Zilog also offers the Z-80 SIO, a more ver- 
satile device that provides synchronous 
(Bisync, HDLC and SDLC) as well as asyn- 
chronous operation. 

The Z-80 DART is fabricated with n-channel 
silicon-gate depletion-load technology, and is 
packaged in a 40-pin plastic or ceramic DIP. 
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Figure 1. Z80 DART Pin Functions Figure 2. Pin Assignments 
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Pin . 
Description 
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B/A. Channel A Or B Select (input, High 
selects Channel B). This input defines which 
channel is accessed during a data transfer be- 


tween the CPU and the Z-80 DART. 


C/D. Control Or Data Select (input, High 
selects Control). This input specifies the type 
of information (control or data) transferred on 
the data bus between the CPU and the Z-80 
DART. 


CE. Chip Enable (input, active Low). A Low at 
this input enables the Z-80 DART to accept 
command or data input from the CPU during a 
write cycle, or to transmit data to the CPU 
during a read cycle. 


CLK. System Clock (input). The Z-80 DART 
uses the standard Z-80 single-phase system 
clock to synchronize internal signals. 


CTSA, CTSB. Clear To Send (inputs, active 
Low). When programmed as Auto Enables, a 
Low on these inputs enables the respective 
transmitter. If not programmed as Auto 
Enables, these inputs may be programmed as 
general-purpose inputs. Both inputs are 
Schmitt-trigger buffered to accommodate slow- 
risetime signals. 


Do-D7. System Data Bus (bidirectional, 
3-state) transfers data and commands between 


the CPU and the Z-80 DART. 
DCDA, DCDB. Data Carrier Detect (inputs, 


active Low). These pins function as receiver 
enables if the Z-80 DART is programmed for 
Auto Enables; otherwise they may be used as 
general-purpose input pins. Both pins are 
Schmitt-trigger buffered. 


DTRA,. DTRB. Data Terminal Ready (outputs, 
active Low). These outputs follow the state pro- 
grammed into the DTR bit. They can also be 
programmed as general-purpose outputs. 


IEI. Interrupt Enable In (input, active High) is 
used with IEO to form a priority daisy chain 
when there is more than one interrupt-driven 
device. A High on this line indicates that no 
other device of higher priority is being ser- 
viced by a CPU interrupt service routine. 


IEO. Interrupt Enable Out (output, active 
High). IEO is High only if IE] is High and the 
CPU is not servicing an interrupt from this 
Z-80 DART. Thus, this signal blocks lower 
priority devices from interrupting while a 
higher priority device is being serviced by its 
CPU interrupt service routine. 


INT. Interrupt Request (output, open drain, 
active Low). When the Z-80 DART is re- 
questing an interrupt, it pulls INT Low. 


Ml. Machine Cycle One (input from Z-80 
CPU, active Low). When M1 and RD are both 
active, the Z-80 CPU is fetching an instruction 
from memory; when M1 is active while IORQ is 
active, the Z-80 DART accepts M1 and IORQ 


as an interrupt acknowledge if the Z-80 DART 
is the highest priority device that has inter- 
rupted the Z-80 CPU. 


IORQ. Jnput/Outout Request (input from CPU, 
active Low). IORQ is used in conjunction with 
B/A, C/D, CE and RD to transfer commands 
and data between the CPU and the Z-80 
DART. When CE, RD and IORO are all 
active, the channel selected by B/A transfers 
data to the CPU (a read operation). When CE 
and IORQ are active, but RD is inactive, the 
channel selected by B/A is written to by the 
CPU with either data or control information as 
specified by C/D. 


RxCA, RxCB. Receiver Clocks (inputs). 
Receive data is sampled on the rising edge of 
RxC. The Receive Clocks may be 1, 16, 32 or 
64 times the data rate. 


RD. Read Cycle Status. (input from CPU, ac- 
tive Low). If RD is active, a memory or I/O 
read operation is in progress. 


RxDA, RxDB. Receive Data (inputs, active 
High). 


RESET. Reset (input, active Low). Disables 
both receivers and transmitters, forces TxDA 
and TxDB marking, forces the modem controls 
High and disables all interrupts. 


RIA, RIB. Ring Indicator (inputs, Active 
Low). These inputs are similar to CTS and 
DCD. The Z-80 DART detects both logic level 
transitions and interrupts the CPU. When not 
used in switched-line applications, these inputs 
can be used as general-purpose inputs. 


RISA. RTSB. Request to Send (outputs, 
active Low). When the RTS bit is set, the RTS 
output goes Low. When the RTS bit is reset, 
the output goes High after the transmitter 
empties. 


TxCA, TxCB. Transmitter Clocks (inputs). TxD 
changes on the falling edge of TxC. The 
Transmitter Clocks may be 1, 16, 32 or 64 
times the data rate; however, the clock 
multiplier for the transmitter and the receiver 
must be the same. The Transmit Clock inputs 
are Schmitt-trigger buffered. Both the Receiver 
and Transmitter Clocks may be driven by the 
Z-80 CTC Counter Time Circuit for program- 
mable baud rate generation. 


TxDA, TxDB. Transmit Data (outputs, active 
High). 


W/RDYA, W/RDYB. Wait/Ready (outputs, 
open drain when programmed for Wait func- 
tion, driven High and Low when programmed 
for Ready function). These dual-purpose out- 
puts may be programmed as Ready lines for a 
DMA controller or as Wait lines that syn- 
chronize the CPU to the Z-80 DART data rate. 
The reset state is open drain. 


Functional 
Description 


2044-001 


The functional capabilities of the Z-80 DART 
can be described from two different points of 
view: as a data communications device, it 
transmits and receives serial data, and meets 
the requirements of asynchronous data com- 
munications protocols; as a Z-80 family 
peripheral, it interacts with the Z-80 CPU and 
other Z-80 peripheral circuits, and shares the 
data, address and control buses, as well as 
being a part of the Z-80 interrupt structure. As 
a peripheral to other microprocessors, the Z-80 
DART offers valuable features such as non- 
vectored interrupts, polling and simple hand- 


Communications Capabilities. The Z-80 
DART provides two independent full-duplex 
channels for use as an asynchronous 
receiver/transmitter. The following is a short 
description of receiver/transmitter capabilities. 
For more details, refer to the Asynchronous 
Mode section of the Z-80 SIO Technical 
Manual. The Z-80 DART offers transmiesion 
and reception of five to eight bits per 
character, plus optional even or odd parity. 
The transmitter can supply one, one and a half 
or two stop bits per character and can provide 
a break output at any time. The receiver break 
detection logic interrupts the CPU both at the 
start and end of a received break. Reception is 
protected from spikes by a transient spike re- 
jection mechanism that checks the signal one- 
half a bit time after a Low level is detected on 
the Receive Data input. If the Low does not 
persist—as in the case of a transient—the 
character assembly process is not started. 


1/O Interface Capabilities. The Z-80 DART 


offers the choice of Polling, Interrupt (vectored 


or non-vectored) and Block Transfer modes to 
transfer data, status and control information to 


INTERNAL 
CONTROL 
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cpu 
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INTERRUPT 
CONTROL 
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INTERRUPT 
CONTROL 
LINES 


+5 VGND CLK 


iNTERNAL BUS 


CHANNEL B 
READ/WRITE 
FEGISTERS 


shake capability. 

The first part of the following functional 
description introduces Z-80 DART data com- 
munications capabilities; the second part 
describes the interaction between the CPU and 
the Z-80 DART. 

A more detailed explanation of Z-80 DART 
operation can be found in the Z-80 SJO Tech- 
nical Manual (Document Number 03-3033-01). 
Because this manual was written for the 
Z-80 SIO, it contains information about syn- 
chronous as well as asynchronous operation. 


Framing errors and overrun errors are 
detected and buffered together with the 
character on which they occurred. Vectored 
interrupts allow fast servicing of interrupting 
conditions using dedicated routines. Further- 
more, a built-in checking process avoids inter- 
preti!.« * framing error as a new start bit: a 
fram‘ vor results in the addition of one-half 
a bit time to the point at which the search for 
the next start bit is begun. 

The Z-80 DART does not require symmetric 
Transmit and Receive Clock signals—a feature 
that allows it to be used with a Z-80 CTC or 
any other clock source. The transmitter and 
receiver can handle data at a rate of 1, 1/16, 
1/32 or 1/64 of the clock rate supplied to the 
Receive and Transmit Clock inputs. When 
using Channel B, the bit rates for transmit and 
receive operations must be the same because 
RxC and TxC are bonded together (RxTxCB). 


and from the CPU. The Block Transfer mode 
can be implemented under CPU or DMA 
control. 
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Figure 3. Block Diagram 
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Functional 
Description 
(Continued) 
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POLLING. There are no interrupts in the 
Polled mode. Status registers RRO and .RR1 are 
updated at appropriate times for each function 
being performed. All the interrupt modes of 
the Z-80 DART must be disabled to operate the 
device in a polled environment. 

While in its Polling sequence, the CPU 
examines the status contained in RRO for each 
channel; the RRO status bits serve as an 
acknowledge to the Poll inquiry. The two RRO 


INTERRUPTS. The Z-80 DART offers an 
elaborate interrupt scheme that provides fast 
interrupt response in real-time applications. As 
a member of the Z-80 family, the Z-80 DART 
can be daisy-chained along with other Z-80 
peripherals for peripheral interrupt-priority 
resolution. In addition, the internal interrupts 
of the Z-80 DART are nested to prioritize the 
various interrupts generated by Channels A 
and B. Channel B registers WR2 and RR2 con- 
tain the interrupt vector that points to an inter- 
rupt service routine in the memory. To 
eliminate the necessity of writing a status 
analysis routine, the Z-80 DART can modify the 
interrupt vector in RR2 so it points directly to 
one of eight interrupt service routines. This is 
done under program control by setting a pro- 
gram bit (WR1, D2) in Channel B called 
“Status Affects Vector.” When this bit is set, 
the interrupt vector in RR2 is modified accord- 
ing to the assigned priority of the various 
interrupting conditions. 

Transmit interrupts, Receive interrupts and 
External/Status interrupts are the main sources 
of interrupts. Each interrupt source is enabled 
under program control with Channel A having 
a higher priority than Channel B, and with 
Receiver, Transmit and External/Status inter- 
rupts prioritized in that order within each 
channel. When the Transmit interrupt is 
enabled, the CPU is interrupted by the 
transmit buffer becoming empty. (This implies 
that the transmitter must have had a data 
character written into it so it can become 


_ CPU/DMA BLOCK TRANSFER. The Z-80 
DART provides a Block Transfer mode to 
accommodate CPU block transfer functions 
and DMA block transfers (Z-80 DMA or other 
designs). The Block Transfer mode uses the 
W/RDY output in conjunction with the 
Wait/Ready bits of Write Register 1. The 
W/RDY output can be defined under software 
control as a Wait line in the CPU Block 


status bits Dy and Dz indicate that a data 
transfer is needed. The status also indicates 
Error or other special status conditions (sée 
“Z-80 DART Programming”). The Special 
Receive Condition status contained in RR1 
does not have to be read in a Polling sequence 
because the status bits in RR] are accom- 
panied by a Receive Character Available 
status in RRO. 


empty.) When enabled, the receiver can inter- 
rupt the CPU in one of three ways: 


@ Interrupt on the first received character 
@ Interrupt on all received characters 
@ Interrupt on a Special Receive condition 


Interrupt On First Character is typically 
used with the Block Transfer mode. Interrupt 
On All Receive Characters can optionally 
modify the interrupt vector in the event of 
a parity error. The Special Receive Condition 
interrupt can occur on a character basis. The 
Special Receive condition can cause an inter- 
rupt only if the Interrupt On First Receive 
Character or Interrupt On All Receive Char- 
acters mode is selected. In Interrupt On First 
Receive Character, an interrupt can occur 
from Special Receive conditions (except Parity 
Error) after the first receive character interrupt 
(example: Receive Overrun interrupt). 

The main function of the External/Status 
interrupt is to monitor the signal transitions of 
the CTS, DCD and RI pins; however, an 
External/Status interrupt is also caused by the 
detection of a Break sequence in the data 
stream. The interrupt caused by the Break 
sequence has a special feature that allows the 
Z-80 DART to interrupt when the Break 
sequence is detected or terminated. This 
feature facilitates the proper termination of the 
current message, correct initialization of the 
next message, and the accurate timing of the 
Break condition. 


Transfer mode or as a Ready line in the DMA 
Block Transfer mode. 

To a DMA controller, the Z-80 DART Ready 
output indicates that the Z-80 DART is ready to 
transfer data to or from memory. To the CPU, 
the Wait output indicates that the Z-80 DART is 
not ready to transfer data, thereby requesting 
the CPU to extend the I/O cycle. 


Internal 
Architecture 


The device internal structure includes a Z-80 
CPU interface, internal control and interrupt 
logic, and two full-duplex channels. Each 
channel contains read and write registers, and 
discrete control and status logic that provides 
the interface to modems or other external 
devices. 

The read and write register group includes 
five 8-bit control registers and two status 
registers. The interrupt vector is written into 
an additional 8-bit register (Write Register 2) 
in Channel B that may be read through Read 
Register 2 in Channel B. The registers for both 
channels are designated as follows: 


WRO-WRS5 — Write Registers 0 through 5 
RRO-RR2 — Read Registers 0 through 2 


The bit assignment and functional grouping 
of each register is configured to simplify and 


Data Path. The transmit and receive data path 
illustrated for Channel A in Figure 4 is iden- 
tical for both channels. The receiver has three 
8-bit buffer registers in a FIFO arrangement in 
addition to the 8-bit receive shift register. This 
scheme creates additional time for the CPU to 


RECEIVE 


DATA 


FIFO 


UO DATA BUFFER 


RECEIVE 
ERRO 
LoGic 


organize the programming process. 

The logic for both channels provides for- 
mats, bit synchronization and validation for’ 
data transferred to and from the channel inter- 
face. The modem control inputs Clear to Send 
(CTS), Data Carrier Detect (DCD) and Ring 
Indicator (RI) are monitored by the control 
logic under program control. All the modem 
control signals are general purpose in nature 
and can be used for functions other than 
modem control. 

For automatic interrupt vectoring, the inter- 
rupt control logic determines which channel 
and which device within the channel has the 
highest priority. Priority is fixed with Channel 
A assigned a higher priority than Channel B; 
Receive, Transmit and External/Status inter- 
rupts are prioritized in that order within each 
channel. 


service a Receive Character Available inter- 
rupt in a high-speed data transfer. 

The transmitter has an 8-bit transmit data 
register that is loaded from the internal data 
bus, and a 9-bit transmit shift register that is 
loaded from the transmit data register. 


TRANSMIT 
2-BIT DELAY 


Figure 4. Data Path 
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Read, 
Write and 
Interrupt 
Timing 


Read Cycle. The timing signals generated by 
a Z-80 CPU input instruction to read a Data or 


Write Cycle. Figure 5b illustrates the timing 
and data signals generated by a Z-80 CPU out- 


Interrupt Acknowledge Cycle. After receiv- 
ing an Interrupt Request signal (INT pulled 
Low), the Z-80 CPU sends an Interrupt 
Acknowledge signal (M1 and IORQ both Low). 
The daisy-chained interrupt circuits determine 
the highest priority interrupt requestor. The IE] 
of the highest priority peripheral is terminated 
High. For any peripheral that has no interrupt 
pending or under service, IEO=IEI. Any 


‘peripheral that does have an interrupt pending 


or under service forces its IEO Low. 


Return From Interrupt Cycle. Normally, the 


Status byte from the Z-80 DART are illustrated 
in Figure 5a. 


put instruction to write a Data or Control byte 
into the Z-80 DART. 


To insure stable conditions in the daisy 
chain, all interrupt status signals are prevented 
from changing while M1 is Low. When IORQ is 
Low, the highest priority interrupt requestor 
(the one with IEI High) places its interrupt vec- 
tor on the data bus and sets its internal 
interrupt-under-service latch. 

Refer to the Z-80 SIO Technical Manual for 
additional details on the interrupt daisy chain 
and interrupt nesting. 


When used with other CPUs, the Z-80 DART 


Z-80 CPU issues an RETI (Return From Inter- 
rupt) instruction at the end of an interrupt ser- 
vice routine. RETI is a 2-byte opcode (ED-4D) 
that resets the interrupt-under-service latch to 
terminate the interrupt that has just been 
processed. 


Ty Tz Tw Ts Ty 
CLOCK 
ce aoc 
1ORQ 
RD 
mi 
DATA OUT 
Figure 5a. Read Cycle 
ty V2 Tw Tw T; % 
CLOCK [ | I | [ l ] | | | I | 
mi \ / 
toRQ \ / 
RD 


DATA 


Figure 5c. Interrupt Acknowledge Cycle 


allows the user to return from the interrupt 
cycle with a special command called “Return 
From Interrupt” in Write Register 0 of Channel 
A. This command is interpreted by the Z-80 
DART in exactly the same way it would inter- 
pret an RETI command on the data bus. 


ile 


CE ( / CHANNEL ADDRESS 


CLOCK 


Figure 5d. Return from Interrupt Cycle 
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Z-80 DART 


To program the Z-80 DART, the system pro- 


Programming gram first issues a series of commands that 


initialize the basic mode and then other com- 
mands that qualify conditions within the select- 
ed mode. For example, the character length, 
clock rate, number of stop bits, even or odd 
parity are first set, then the Interrupt mode 
and, finally, receiver or transmitter enable. 


Both channels contain command registers 
that must be programmed via the system pro- 
gram prior to operation. The Channel Select 
input (B/A) and the Control/Data input (C/D) 
are the command structure addressing con- 
trols, and are normally controlled by the CPU 
address bus. 


Write Registers. The Z-80 DART contains six 
registers (WRO-WRS) in each channel that are 
programmed separately by the system program 
to configure the functional personality of the 
channels (Figure 4). With the exception of 
WRO, programming the write registers requires 
two bytes. The first byte contains three bits 
(Do-D2) that point to the selected register; the 
second byte is the actual control word that is 
written into the register to configure the Z-80 
DART. 

WRO is a special case in that all the basic 
commands (CMD,)-CMD,) can be accessed 
with a single byte. Reset (internal or external) 
initializes the pointer bits Dp-D2 to point to 
WRO. This means that a register cannot be 


Read Registers. The Z-80 DART contdins 
three registers (RRO-RR2) that can be read to 
obtain the status information for each channel 
(except for RR2, which applies to Channel B 
only). The status information includes error 
conditions, interrupt vector and standard 
communications-interface signals. 

To read the contents of a selected read 
register other than RRO, the system program 
must first write the pointer byte to WRO in 
exactly the same way as a write register opera- 
tion. Then, by executing an input instruction, 
the contents of the addressed read register can 
be read by the CPU. 


pointed to in the same operation as a channel 
reset. 


Write Register Functions 


WRO Register pointers, initialization commands for 
the various modes, etc. 


WRI Transmit/Receive interrupt and data transfer 
mode definition. 


WR2_ Interrupt vector (Channel B only) 
WR3 _ Receive parameters and control 


WR4_ Transmit/Receive miscellaneous parameters 
and modes 


WRS5_ Transmit parameters and controls 


The status bits of RRO and RR1 are carefully 
grouped to simplify status monitoring. For 
example, when the interrupt vector indicates 
that a Special Receive Condition interrupt has 
occurred, all the appropriate error bits can be 
read from a single register (RR1). 


Read Register Functions 


RRO Transmit/Receive buffer status, interrupt 
status and external status 


RR1 Special Receive Condition status 
RR2 Modified interrupt vector (Channel B only) 
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Z-80 DART 
Read and Write 
Registers | 


READ REGISTER 1° 


READ REGISTER 0 


| L ALL SENT 
NOT USED 


PARITY ERROR 

Rx OVERRUN ERROR 
FRAMING ERROR 
NOT USED 


"Used With Special Receive Condition Mode 


WRITE REGISTER 0 


a~e244O000 
a~-0O0~4200 
@=O4O AR 0-40 


— 


0 t) 0 REGISTER 0 
0 0 1 REGISTER 1 
0 1 i) REGISTER 2 
i) 1 1 REGISTER 3 
1 ty 0 REGISTER 4 
t Q 1 REGISTER § 

NULL CODE 

NOT USED 


RESET EXT/STATUS INTERRUPTS 
CHANNEL RESET 

ENABLE INT ON NEXT Rx CHARACTER 
RESET TxINT PENDING 

ERROR RESET 

RETURN FROM INT (CH-A ONLY) 


NOT USED 


WRITE REGISTER 2 (CHANNEL B ONLY) 


[ts 
v1 
v2 
v3 INTERRUPT 
va VECTOR 
v5 
v6 


WRITE REGISTER 4 


| Le PARITY ENABLE 
PARITY EVEN/ODD 


0 0 
0 1 
1 0 
1 1 
0 0 
) 1 
1 0 
1 1 


NOT USED 

1 STOP BITICHARACTER 
1% STOP BITS/CHARACTER 
2 STOP BITSICHARACTER 


NOT USED 


X1 CLOCK MODE 
X16 CLOCK MODE 
X32 CLOCK MODE 
X64 CLOCK MODE 


Rx CHARACTER AVAILABLE 
INT PENDING (CH. A ONLY) 
Tx BUFFER EMPTY 


USED WITH “EXTERNAL/ 
STATUS INTERRUPT" 


NOT usED | MODE 


READ REGISTER 2 


[Pr] Pe | Ds | 0. ] D3] D2] Ds [Do 
L vo 


viee 
v2** 


V3"* \ INTERRUPT 
va VECTOR 


**Variabie If “Status Affects 
Vector” Is Programmed 


WRITE REGISTER 1 


[Pr 5} 0s [04 [D3] 0. ] Ds] 00) 
| E EXT INT ENABLE 
Tx INT ENABLE 


; STATUS AFFECTS VECTOR 


(CH. B ONLY) 


0 0 Rx INT DISABLE 
0 1 Rx INT ON FIRST CHARACTER 


1 0 INT ON ALL Rx CHARACTERS (PARITY 


AFFECTS VECTOR) 


1 1 INT ON ALL Rx CHARACTERS (PARITY 


DOES NOT AFFECT VECTOR) 
WAITIREADY ON R/T 


WAITIREADY FUNCTION 
WAITIREADY ENABLE 


WRITE REGISTER 3 


OR ON 
SPECIAL 
RECEIVE 


CONDITION 


| Le Rx ENABLE 
NOT USED 
AUTO ENABLES 
Rx § BITSICHARACTER 


Rx 6 BITSICHARACTER 


0 0 
0 1 Rx 7 BITSICHARACTER 
1 0 
1 1 


Rx 8 BITSICHARACTER 


WRITE REGISTER § 


JD; | Dg | Os [Ds | D3 1021 0, [Op 


is NOT USED 
ATS 
NOT USED 
Tx ENABLE 
SEND BREAK 


Tx 5 BITS (OR LESSV'CHARACTER 
Tx 7 BITSICHARACTER 
Tx 6 BITSICHARACTER 
Tx 8 BITSICHARACTER 
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28420 
Z80° PiO Parallel 
Input/Output Controller 


Product 


& age a 
Zilog Specification 
March 1981 
Features @ Provides a direct interface between Z-80 ® Programmable interrupts on peripheral 
microcomputer systems and peripheral status conditions. 
devices. m Standard Z-80 Family bus-request and 
® Both ports have interrupt-driven handshake prioritized interrupt-request daisy chains 
for fast response. impl-'nented without external logic. 
g Four programmable operating modes: byte . @ The eight Port B outputs can drive Dar- 
input, byte output, byte input/output (Port A lington transistors (1.5 mA at 1.5 V). 
only), and bit input/output. 
General _ The Z-80 PIO Parallel I/O Circuit is a pro- accomplished under interrupt control. Thus, 
Description | grammable, dual-port device that provides a the interrupt logic of the PIO permits full use 


TTL-compatible interface between peripheral 
devices and the Z-80 CPU. The CPU config- 
ures the Z-80 PIO to interface with a wide 
range of peripheral devices with no other 
external logic. Typical peripheral devices that 
are compatible with the Z-80 PIO include most 
keyboards, paper tape readers and punches, 
printers, PROM programmers, etc. 

One characteristic of the Z-80 peripheral 
controllers that separates them from other 
interface controllers is that all data transfer 
between the peripheral device and the CPU is 


DATA 

BUS 
PORTA 

PIO 

CONTROL 
PORT B 

INTERRUPT 

CONTROL 


Figure 1. Pin Functions 


of the efficient interrupt capabilities of the 
Z-80 CPU during I/O transfers. All logic 
necessary to implement a fully nested interrupt 
structure is included in the PIO. 

Another feature of the PIO is the ability to 
interrupt the CPU upon occurrence of speci- 
fied status conditions in the peripheral device. 
For example, the PIO can be programmed to 
interrupt if any specified peripheral alarm con- 
ditions should occur. This interrupt capability 
reduces the time the processor must spend in 
polling peripheral status. 
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Figure 2. Pin Assignments 
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General 
Description 
(Continued) 


The Z-80 PIO interfaces to peripherals via 
two independent general-purpose I/O ports, 
designated Port A and Port B. Each port has 
eight data bits and two handshake signals, 
Ready and Strobe, which control data transfer. 
The Ready output indicates to the peripheral 
that the port is ready for a data transfer. 
Strobe is an input from the peripheral that 
indicates when a data transfer has occurred. 


Operating Modes. The Z-80 PIO ports can be 
programmed to operate in four modes: byte 
output (Mode 0), byte input (Mode 1), byte 
input/output (Mode 2) and bit input/output . 
(Mode 3). 

In Mode 0, either Port A or Port B can be 
programmed to output data. Both ports have 
output registers that are individually addressed 
by the CPU; data can be written to either port 
at any time. When data is written to a port, an 
active Ready output indicates to the external 
device that data is available at the associated 
port and is ready for transfer to the external 
device. After the data transfer, the external 
device responds with an active Strobe input. 
which generates an interrupt, if enabled. 

In Mode 1, either Port A or Port B can be 
configured in the input mode. Each port has 
an input register addressed by the CPU. When 
the CPU reads data from a port, the PIO sets 
the Ready signal, which is detected by the 
external device. The external device then 
places data on the I/O lines and strobes the 
I/O port, which latches the data into the Port 
Input Register, resets Ready, and triggers the 
Interrupt Request, if enabled. The CPU can 
read the input data at any time, which again 
sets Ready. 

Mode 2 is bidirectional and uses Port A, 
plus the interrupts and handshake signals from 
both ports. Port B must be set to Mode 3 and 
masked off. In operation, Port A is used for 
both data input and output. Output operation 
is similar to Mode 0 except that data is allowed 
out onto the Port A bus only when ASTB is 
Low. For input, operation is similar to Mode 1, 
except that the data input uses the Port B 
handshake signals and the Port B interrupt (if 
enabled). 

Both ports can be used in Mode 3. In this 
mode, the individual bits are defined as either 
input or output bits. This provides up to eight 
separate, individually defined bits for each 
port. During operation, Ready and Strobe are 


not used. Instead, an interrupt is generated if 
the condition of one input changes, or if all 
inputs change. The requirements for gener- 
ating an interrupt are defined during the pro- 
gramming operation; the active level is 
specified as either High or Low, and the logic 
condition is specified as either one input active 
(OR) or all inputs active (AND). For example, 
if the port is programmed for active Low 
inputs and the logic function is AND, then all 
inputs at the specified port must go Low to 
generate an interrupt. 

Data outputs are controlled by the CPU and 
can be written or changed at any time. 


@ Individual bits can be masked off. 


@ The handshake signals are not used in 
Mode 3; Ready is held Low, and Strobe is 
disabled. 


@ When using the Z-80 PIO interrupts, the 
Z-80 CPU interrupt mode must be set to 
Mode 2. 
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Figure 3. PIO in a Typical Z80 Family Environment 
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Internal 
Structure 
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The internal structure of the Z-80 PIO con- 
sists of a Z-80 CPU bus interface, internal con- 
trol logic, Port A I/O logic, Port B I/O logic, 
and interrupt control logic (Figure 4). The 
CPU bus interface logic allows the Z-80 PIO to 
interface directly to the Z-80 CPU with no 
other external logic. The internal control logic 
synchronizes the CPU data bus to the per- 
ipheral device interfaces (Port A and Port B). 
The two I/O ports (A and B) are virtually 
identical and are used to interface directly to 
peripheral devices. 


Port Logic. Each port contains separate input 
and output registers, handshake control logic, 
and the control registers shown in Figure 5. 
All data transfers between the peripheral unit 
and the CPU use the data input and output 
registers. The handshake logic associated with 
each port controls the data transfers through 
the input and the output registers. The mode 
control register (two bits) selects one of the 
four programmable operating modes. 

The control mode (Mode 3) uses the remain- 
ing registers. The input/output control register 
specifies which of the eight data bits in the 
port are to be outputs and enables these bits; 
the remaining bits are inputs. The mask reg- 
ister and the mask control register control 
Mode 3 interrupt conditions. The mask register 
specifies which of the bits in the port are 
active and which are masked or inactive. 
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CONTROL 


INTERRUPT 
CONTROL 
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INTERRUPT CONTROL LINES 
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The mask control register specifies two 
conditions: first, whether the active state of 
the input bits is High or Low, and second, 
whether an interrupt is generated when any 
one unmasked input bit is active (OR condi- 
tion) or if the interrupt is generated when 
all unmasked input bits are active (AND 
condition). 


Interrupt Control Logic. The interrupt control 
logic section handles all CPU interrupt pro- 
tocol for nested-priority interrupt structures. 
Any device's physical location in a daisy-chain 
configuration determines its priority. Two lines 
(IEI and IEO) are provided in each PIO to 
form this daisy chain. The device closest to the 
CPU has the highest priority. Within a PIO, 
Port A interrupts have higher priority than 
those of Port B. In the byte input, byte output, 
or bidirectional modes, an interrupt can be 
generated whenever the peripheral requests a 
new byte transfer. In the bit control mode, an 
interrupt can be generated when the periph- 
eral status matches a programmed value. The 
PIO provides for complete control of nested 
interrupts. That is, lower priority devices may 
not interrupt higher priority devices that have 
not had their interrupt service routines com- 
pleted by the CPU. Higher priority devices 
may interrupt the servicing of lower priority 
devices. 
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Figure 4. Block Diagram 


47 


Old 082 


Internal If the CPU (in interrupt Mode 2) accepts an 
Structure interrupt, the interrupting device must provide 
(Continued) an 8-bit interrupt vector for the CPU. This vec- 


tor forms a pointer to a location in memory 
where the address of the interrupt service 
routine is located. The 8-bit vector from the 
interrupting device forms the least significant 
eight bits of the indirect pointer while the’ 

I Register in the CPU provides the most signifi- 
cant eight bits of the pointer. Each port (A and 
B) has an independent interrupt vector. The 
least significant bit of the vector is automati- 
cally set to 0 within the PIO because the 
pointer must point to two adjacent memory 
locations for a complete 16-bit address. 

Unlike the other Z-80 peripherals, the PIO 
does not enable interrupts immediately after 
programming. It waits until M1 goes Low (e.g., 
during an opcode fetch). This condition is 
unimportant in the Z-80 environment but might 
not be if another type of CPU is used. 

The PIO decodes the RET] (Return From 


(2 BITS) 


MASK 
REGISTER 
{8 BITS) 


. (2 BITS) 


Loic 


*Used In the bit mode only to allow generation of an 


interrupt if the peripheral W/O pins go to the specified state. 


Poo ANTERNAL BUS 


INTERRUPT 
CONTROL 


Interrupt) instruction directly from the CPU 
data bus so that each PIO in the system knows 
at all times whether it is being serviced by the 
CPU interrupt service routine. No other com- 
munication with the CPU is required. 


CPU Bus I/O Logic. The CPU bus interface 
logic interfaces the Z-80 PIO directly to the 
Z-80 CPU, so no external logic is necessary. 
For large systems, however, address decoders 
and/or buffers may be necessary. 


Internal Control Logic. This logic receives the 
control words for each port dufing program- 
ming and, in turn, controls the operating func- 
tions of the Z-80 PIO. The control logic syn- 
chronizes the port operations, controls the port 
mode, port addressing, selects the read/write 
function, and issues appropriate commands to 
the ports and the interrupt logic. The Z-80 PIO 
does not receive a write input from the CPU; 
instead, the RD, CE, C/D and IORQ signals 
generate the write input internally. 


s 
INPUT/ 
OUTPUT 
SELECT 
REGISTER 
(8 BITS) 


DATA 
OUTPUT 
REGISTER 
(8 BITS) 


<) 8-BIT 10 BUS 


DATA 
—“]_ INPUT 

-| REGISTER 
(8 BITS) 


HANDSHAKE 
STROBE | CONTROL 
——_—_—_—_——— 


Figure 5. Typical Port I/O Block Diagram 
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Programming Mode 0, 1, or 2. (Byte Input, Output, or 


Bidirectional). Programming a port for Mode 
0, 1, or 2 requires two words per port. These 
words are: 

A Mode Control Word. Selects the port operating mode 
(Figure 6). This word may be written any time. 


An Interrupt Vector. The Z-80 PIO is designed for use with 
the Z-80 CPU in interrupt Mode 2 (Figure 7). When inter- 
rupts are enabled, the PIO must provide an interrupt 
vector. 


Mode 3. (Bit Input/Output). Programming a 
port for Mode 3 operation requires a control 
word, a vector (if interrupts are enabled), and 
three additional words, described as follows: 


I/O Register Control. When Mode 3 is selected, the mode 
control word must be followed by another control word that 
sets the I/O control register, which in turn defines which 
port lines are inputs and which are outputs (Figure 8). 


coee Mee IDENTIFIES MODE 
CONTROL WORD 
DON'T CARE 
MODE SELECT 


© 0 MODEO 
0 1 MODE1 
1 0 MODE2 
1 4 MODE3 


Figure 6. Mode Control Word 


L IDENTIFIES INTERRUPT 
VECTOR 


USER SUPPLIED INTERRUPT 
VECTOR 


Figure 7. Interrupt Vector Word 


aie Pas 


0 SETS BIT TO OUTPUT 
1 SETS BIT TO INPUT 


Figure 8. I/O Register Control Word 


Interrupt Control Word. In Mode 3, handshake is not 
used. Interrupts are generated as a logic function of the 
input signal levels. The interrupt control word sets the 
logic conditions and the logic levels required for gener- 
ating an interrupt. Two logic conditions or functions are 
available: AND (if all input bits change to the active level, 
an interrupt is triggered), and OR (if any one of the input 
bits changes to the active level, an interrupt is triggered). 
Bit Dg sets the logic function, as shown in Figure 9. The 
active level of the input bits can be set either High or Low. 
The active level is controlled by Bit Ds. 


Mask Control Word. This word sets the mask control 
register, allowing any unused bits to be masked off. If any 
bits are to be masked, then D4 must be set. When Dz is set, 
the next word written to the port must be a mask control 
word (Figure 10). 


Interrupt Disable. There is one other control 
word which can be used to enable or disable a 
port interrupt. It can be used without changing 
the rest of the interrupt control word 

(Figure 11). 


| IDENTIFIES INTERRUPT 
CONTROL WORD 
D, = 0 NO MASK WORK FOLLOWS 
, O, = 1 MASK WORD FOLLOWS 
Os = 0 ACTIVE LEVEL IS LOW 
Ds = 1 ACTIVE LEVEL IS HIGH 
Dg = 0 INTERRUPT ON OR FUNCTION 
Dg = 1 INTERRUPT ON AND FUNCTION 


Dy = 0 INTERRUPT DISABLED 
D7 = 1 INTERRUPT ENABLED* 


*NOTE: THE PORT {S NOT ENABLED UNTIL 
THE INTERRUPT ENABLE IS FOLLOWED 
SY AN ACTIVE M1. 


Figure 9. Interrupt Control Word 


MBy-MB; MASK BITS. A 
BIT IS MONITORED FOR AN 
INTERRUPT IF IT 1S 


DEFINED AS AN INPUT AND 
THE MASK BIT tS SET TO 0. 


Figure 10. Mask Control Word 


IDENTIFIES INTERRUPT 
DISABLE WORD 


F 


OON'T CARE 


D, = 0 INTERRUPT DISABLE 
D, = 1 INTERRUPT ENABLE 


Figure 11. Interrupt Disable Word 
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Pin 
Description 


50 


Ao- Ay. Port A Bus (bidirectional, 3-state). 
This 8-bit bus transfers data, status, or control 
information between Port A of the PIO anda 


peripheral device. Ag is the least significant 
bit of the Port A data bus. 


ARDY. Register A Ready (output, active 
High). The meaning of this signal depends on 
the mode of operation selected for Port A as 
follows: 


Output Mode. This signal goes active to indicate that the 
Port A output register has been loaded and the peripheral 
data bus is stable and ready for transfer to the peripheral 
device. 


Input Mode. This signal is active when the Port A input 
register is empty and ready to accept data from the 
peripheral device. 

Bidirectional Mode. This signal is active when data is 
available in the Port A output register for transfer to the 
peripheral device. In this mode, data is not placed on the 
Port A data bus, unless ASTB is active. 


Control Mode. This signal is disabled and forced to a Low 
state. 

ASTB. Port A Strobe Pulse From Peripheral 
Device (input, active Low). The meaning of 
this signal depends on the mode of operation 
selected for Port A as follows: 


Output Mode. The positive edge of this strobe is issued by 
the peripheral to acknowledge the receipt of data made 
available by the PIO. 


Input Mode. The strobe is issued by the peripheral to load 
data from the peripheral into the Port A input register. 
Data is loaded into the PIO when this signal is active. 


Bidirectional Mode. When this signal is active, data from 
the Port A output register is gated onto the Port A bidirec- 
tional data bus. The positive edge of the strobe acknowl- 
edges the receipt of the data. 


Control Mode. The strobe is inhibited internally. 

Bo-By. Port B Bus (bidirectional, 3-state). This 
8-bit bus transfers data, status, or control 
information between Port B and a peripheral 
device. The Port B data bus can supply 


1.5 mA at 1.5 V to drive Darlington transistors. 


Bo is the least significant bit of the bus. 


B/A. Port B Or A Select (input, High = B). 
This pin defines which port is accessed during 
a data transfer between the CPU and the PIO. 
A Low on this pin selects Port A; a High 
selects Port B. Often address bit Ag from the 
CPU is used for this selection function. 


BRDY. Register B Ready (output, active High). 


This signal is similar to ARDY, except that in 
the Port A bidirectional mode this signal is 
High when the Port A input register is empty 
and ready to accept data from the peripheral 
device. 


BSTB. Port B Strobe Pulse From Peripheral 
Device (input, active Low). This signal is 
similar to ASTB, except that in the Port A 
bidirectional mode this signal strobes data 
from the peripheral device into the Port A 
input register. 


C/D. Contro/ Or Data Select (input, 

High = C). This pin defines the type of data 
transfer to be performed between the CPU and 
the PIO. A High on this pin during a CPU 
write to the PIO causes the Z-80 data bus to be 
interpreted as a command for the port selected 
by the B/A Select line. A Low on this pin 
means that the Z-80 data bus is being used to 
transfer data between the CPU and the PIO. 
Often address bit A) from the CPU is used for 
this. function. 


CE. Chip Enable (input, active Low). A Low 
on this pin enables the PIO to accept com- 
mand or data inputs from the CPU during a 
write cycle or to transmit data to the CPU dur- 
ing a read cycle. This signai is generally 
decoded from four I/O port numbers for Ports 
A and B, data, and control. 


CLK. System Clock (input). The Z-80 PIO uses 
the standard single-phase Z-80 system clock. 


Do-D7. 2-80 CPU Data Bus (bidirectional, 
3-state). This bus is used to transfer all data 
and commands between the Z-80 CPU and the 
Z-80 PIO. Do is the least significant bit. 


IEI. Interrupt Enable In (input, active High). 
This signal is used to form a priority-interrupt 
daisy chain when more than one interrupt- 
driven device is being used. A High level on 
this pin indicates that no other devices of 
higher priority are being serviced by a CPU 
interrupt service routine. 


IEO. Interrupt Enable Out (output, active 
High). The IEO signal is the other signal 
required to form a daisy chain priority scheme. 
It is High only if IEI is High and the CPU is 
not servicing an interrupt from this PIO. Thus 
this signal blocks lower priority devices from 
interrupting while a higher priority device is 
being serviced by its CPU interrupt service 
routine. 


INT. Interrupt Request (output, open drain, 
active Low). When INT is active the Z-80 PIO 
is requesting an interrupt from the Z-80 CPU. 


IORQ. Input/Output Request (input from Z-80 
CPU, active Low). IORQ is used in conjunc- 
tion with B/A, C/D, CE, and RD to transfer 
commands and data between the Z-80 CPU and 
the Z-80 PIO. When CE, RD, and IORO are 
active, the port addressed by B/A transfers 
data to the CPU (a read operation). Con- 
versely, when CE and [ORO are active but RD 
is not, the port addressed by B/A is written 
into from the CPU with either data or control 
information, as specified by C/D. Also, if 
[ORO and M1 are active simultaneously, the 
CPU is acknowledging an interrupt; the inter- 
rupting port automatically places its interrupt 
vector on the CPU data bus if it is the highest 
priority device requesting an interrupt. 


Pin 
Description 
(Continued) 


Ml. Machine Cycle (input from CPU, active 
Low). This signal is used as a sync pulse to 
control several internal PIO operations. When 
both the M1 and RD signals are active, the 
Z-80 CPU is fetching an instruction from 
memory. Conversely, when both M1] and 


' IORQ are active, the CPU is acknowledging 


an interrupt. In addition, M1 has two other 
functions within the Z-80 PIO: it synchronizes 


the PIO interrupt logic; when M1 occurs 
without an active RD or IORQ signal, the PIO 
is reset. 


RD. Read Cycle Status (input from Z-80 CPU, 
active Low). If RD is active, or an I/O opera- 
tion is in progress, RD is used with B/A, C/D, 
CE, and IORQ to transfer data from the Z-80 
PIO to the Z-80 CPU. 


Timing 


The following timing diagrams show typical 
timing in a Z-80 CPU environment. For more 
precise specifications refer to the composite 
ac timing diagram. 


Write Cycle. Figure 12 illustrates the 
timing for programming the Z-80 PIO 

or for writing data to one of its ports. No 
Wait states are allowed for writing to the 
PIO other than the automatically inserted 
Twa. The PIO does not receive a speci- 
fic write signal; it internally generates 
its own from the lack of an active 

RD signal. 


Read Cycle. Figure 13 illustrates the timing 
for reading the data input from an external 

device to one of the Z-80 PIO ports. No Wait 
states are allowed for reading the PIO other 


.than the automatically inserted Twa. 


Output Mode (Mode 0). An output cycle 
(Figure 14) is always started by the execution 
of an output instruction by the CPU. The WR* 
pulse from the CPU latches the data from the 
CPU data bus into the selected port's output 
register. The WR* pulse sets the Ready flag 
after a Low-going edge of CLK, indicating 
data is available. Ready stays active until the 
positive edge of the . trobe line is received, 
indicating that data was taken by the periph- 
eral. The positive edge of the strobe pulse 
generates an INT if the interrupt enable flip- 
flop has been set and if this device has the 
highest priority. 


CLK 


Ty T2 Twa Ty qt 


*RD = RD CE* C/De IORQ 


Figure 13. Read Cycle Timing . 


a 


“WR = RD CE C/D « IORO 


Figure 14. Mode 0 Output Timing 
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Timing 
(Continued) 
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Input Mode (Mode 1). When STROBE goes 
Low, data is loaded into the selected port input 
register (Figure 15). The next rising edge of 
strobe activates INT, if Interrupt Enable is set 
and this is the highest-priority requesting 
device. The following falling edge of CLK 
resets Ready to an inactive state, indicating 


CLK v 


STROBE D 
SAMPLE 
port —-—-— —_—— 


ee 


i. Sa 


that the input register is full and cannot accept 
any more data until the CPU completes a read. 
When a read is complete, the positive edge of 
RD sets Ready at the next Low-going transition 
of CLK. At this. time new data can be loaded 
into the PIO. 


Figure 15. Mode 1 Input Timing 


Bidirectional Mode (Mode 2). This is a com- 
bination of Modes 0 and 1 using all four hand- 
shake lines and the eight Port A I/O lines 
(Figure 16). Port B must be set to the bit mode 
and its inputs must be masked. The Port A 
handshake lines are used for output control 


and the Port B lines are used for input control. 


ARDY 


“WR = RD e CEe C/De IORQ 


If interrupts occur, Port A’s vector will be used 
during port output and Port B’s will be used 
during port input. Data is allowed out onto the 
Port A bus only when ASTB is Low. The rising 
edge of this strobe can be used to latch the 
data into the peripheral. 


SAMPLE 


Figure 16. Mode 2 Bidirectional Timing 
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Timing 
(Continued) 


Bit Mode (Mode 3). The bit mode does not 
utilize the handshake signals, and a normal 
port write or port read can be executed at any 
time. When writing, the data is latched into 
the output registers with the same timing as the 
output mode (Figure 17). 

When reading the PIO, the data returned to 
the CPU is composed of output register data 
from those port data lines assigned as outputs 
and input register data from those port data 


PORT 
DATA BUS 


nal DATA MATCH 
OCCURS HERE 


lines assigned as inputs. The input register 
contains data that was present immediately 
prior to the falling edge of RD. An interrupt is 
generated if interrupts from the port are 
enabled and the data on the port data lines 
satisfy the logical equation defined by the 8-bit 
mask and 2-bit mask control registers. How- 
ever, if Port A is programmed in bidirectional 
mode, Port B does not issue an interrupt in bit 
mode and must therefore be polled. 


DATA WORD 1 DATA WORD 2 


“Timing Diagram Refers to Bit Mode Read 


DATA WORD 1 PLACED ON 8US 


Figure 17. Mode 3 Bit Mode Timing 


Interrupt Acknowledge Timing. During M1 
time, peripheral controllers are inhibited from 
changing their interrupt enable status, permit- 
ting the Interrupt Enable signal to ripple 
through the daisy chain. The peripheral with 
IEI High and IEO Low during INTACK places 
a preprogrammed 8-bit interrupt vector on the 
data bus at this time (Figure 18). IEO is held 
Low until a Return From Interrupt (RETI) 
instruction is executed by the CPU while IE] is 
High. The 2-byte RETI instruction is decoded 
internally by the PIO for this purpose. 


Return From Interrupt Cycle. If a Z-80 per- 
ipheral has no interrupt pending and is not 
under service, then its IEO = IEI. If it has an 
interrupt under service (i.e., it has already 
interrupted and received an interrupt acknowl- 
edge) then its IEO.is always Low, inhibiting 
lower priority devices from interrupting. If it 
has an interrupt pending which has not yet 
been acknowledged, IEO is Low unless an 
“ED” is decoded as the first byte of a 2-byte 
opcode (Figure 19). In this case, IEO goes 
High until the next opcode byte is decoded, 
whereupon it goes Low again. If the second 
byte of the opcode was a “4D,” then the 
opcode was an RETI instruction. 

After an “ED” opcode is decoded, only the 
peripheral device which has interrupted and is 
currently under service has its IE] High and its 


LASTT 
era ms | T2 | Twa 


CLK 
SAMPLE 
aes INT 


cae 1ORG AND M1 
1onQ | INDICATE 


INTERRUPT 
| ACKNOWLEDGE 
iNTACK 


Ty 


Twa 


120 \ 


Figure 18. Interrupt Acknowledge Timing 


IEO Low. This device is the highest-priority 
device in the daisy chain that has received an 
interrupt acknowledge. All other peripherals 
have IEI = IEO. If the next opcode byte 
decoded is “4D,” this peripheral device resets 
its “interrupt under service” condition. 


Figure 19. Return From Interrupt 
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CLOCK 


_ cE 
BIA, CID 


RD, lORQ 


OUT 


Do-D7 


tORQ 


it =) 
EO 


READY 
(ARDY OR BRDY) 


STROBE 
(ASTB OR BSTB) 


MODE0O 
MODE 1 
Ao-A?7 
Bo-By 
MODE 2 
MODE 3 
INT 
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Z-80 PIO Z-80A PIO Z-80B PIOI9! 
Min Max Min Max Min Max 


Number Symbol Parameter (ns) (ns) (ns) (ns) (ns) (ns) Comment 
1 TcC Clock Cycle Time 400 (1] 250 (1) 165 (1) 
2 TwCh Clock Width (High) 170 2000 105 2000 65 2000 
3 TwCl Clock Width (Low) 170 2000 105 2000 65 2000 
4 TiC Clock Fall Time 30 30 20 
5— TrC—————_ Clock Rise Time > 30 -—- 30 -—— 20 
6  TsCS(RI) CE, B/A, C/D to RD, 
IORQ 3} Setup Time 50 50 50 [6] 
7 Th Any Hold Times for Specified 
Setup Time 0 0 0 0 
8 TsRI(C) RD, IORQ to Clock t Setup 
Time 115 115 70 
9— TdRI(DO)—— RD, IORQ to Data Out Delay 40 —-- 380 ———- 300 ————__ [2] —— 
10 TdRI(DOs) RD, IORQ 1 to Data Out Float 
Delay 160 110 70 
11 TsDI(C) Data In to Clock ! Setup Time 50 50 40 CL = 50 pF 
12 TdIO(DOID) IORQ 3 to Data Out Delay 
(INTACK Cycle) 340 160 120 (3] 
13—— TsM1(Cr) M1 | to Clock t Setup Time 210-——--~——- 90 —_—__ 70 
14 TsM1(Cf) M11 to Clock | Setup Time 
(M1 Cycle) 0 0 0 [8] 
15 TdM1(IEO) M1 ! to IEO | Delay (Interrupt 
Immediately Preceding M1 }) 300 190 100 (5, 7] 
16 = TsIEI(IO) IEI to IORQ | Setup Time 
(INTACK Cycle) 140 140 100 [7] 
17 —— TdIEI(IEOf)—— IEI } to IEO | Delay - —————————-—_ 190 --__ 130 —---—_ 120- -______—___ [5] ———- 
CL = 50 pF 
18 TdIEI(IEOr) IE] t to IEO 1 Delay (after ED 
Decode) ; 210 160 160 [5] 
19 TcIO(C) IORQ t to Clock | Setup Time 
(To Activate READY on Next 
Clock Cycle) 220 260 170 
20 — TdC(RDYr)—— Clock ! to READY t Delay 200-—-—- 190 —— 170 _—__—__—_____—_ [5] 
CL = 50 pF 
21 TdC(RDYf) Clock |} to READY ! Delay 150 140 120 {5] 
22 TwSTB “STROBE Pulse Width 150 ~ 150 120 [4] 
23 TsSTB(C) “STROBE t to Clock | Setup 
Time (To Activate READY on 
Next Clock Cycle) 220 220 150 [5] 
24 —-TdIO(PD)——- IORQ 1 to PORT DATA Stable 
Delay (Mode 0) 200 180 160 [5] 
25 TsPD(STB) PORT DATA to STROBE t 
Setup Time (Mode 1!) 260 230 190 
26 TdSTB(PD) STROBE |! to PORT DATA 
Stable (Mode 2) 230 210 180 {5] 
27 —TdSTB(PDr)—— STROBE ! to PORT DATA Float ———HH— SS 
Delay (Mode 2) 200 180 160 CL = 50 pF 
28 TdPD(INT) PORT DATA Match to INT } 
Delay (Mode 3) 540 490 430 
29 TdSTB(INT) STROBE | to INT ! Delay 490 440 350 
NOTES: {6] TsCS(RI) may be reduced. However, the time subtracted 
(1) TeC = TwCh + TwCl + TrC + TIC. from TsCS(RI) will be added to TdRI(DO). 
[2] Increase TdRI(DO) by 10 ns for each 50 pF increase in load [7] 2.5 TcC > (N-2)TdIEI(IEOf) + TaMI(IEO) + TsIEI(IO) 
up to 200 pF max. + TTL Buffer Delay, if any. 
[3] Increase TdIO(DOI) by 10 ns for each 50 pF, increase in [8] M1 must be active for a minimum of two clock cycles to 
loading up to 200 pF max. reset the PIO. 
[4] For Mode 2: TwSTB > TsPD(STB). [9} Z80B PIO numbers are preliminary and subject to change. 


[5] Increase these values by 2 ns for each 10 pF increase in 
loading up to 100 pF max. 
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Absolute 


Voltages on all inputs and outputs 


Stresses greater than those listed under Absolute Maxi- 


Maximum with respect toGND.......... -0.3Vto +7.0V ‘mum Ratings may cause permanent damage to the device. 
Ratings ; : This is a stress rating only; operation of the device at any 
cung Operating Ambient condition above those indicated in the operational sections 
Temperature ............0000 As Specified in of these specifications is not implied. Exposure to absolute 
Ordering Information maximum rating conditions for extended periods may affect 
device reliability. 
Storage Temperature........ -65°C to +150°C 
Test The characteristics below apply for the Ordering Information section. 
Conditions following standard test conditions, unless All ac parameters assume a load capacitance 
otherwise noted. All voltages are referenced to of 100 pF max. Timing references between two 
GND (0 V). Positive current flows into the output signals assume a load difference of 
referenced pin. Available operating 50 pF max. 
temperature ranges are: 
gm 0° to +70°C, + 
+4.75 V Ss Vog S +5.25 V 24K 
mw -40°C to +85°C, THUNDER TEST 
+4.75 V S Voo S +5.25 V 
w -55° to +125°C, 100 oF na 
+4.75V s Voc S +5.5V [ 
The product number for each operating Te Oe 
temperature range may be found in the 
DC Symbol Parameter Min Max Unit Test Condition 
Charac- 
teristics Vite Clock Input Low Voltage -0.3 +0.45 V 
Vic Clock Input High Voltage Vec-0.6 +5.5 V 
Vit Input Low Voltage -0.3 +0.8 V 
Vin Input High Voltage +2.0 +5.5 V 
VoL Output Low Voltage +0.4 V Ip, = 2.0 mA 
Vou Output High Voltage +2.4 V loy = -250 pA 
ly Input Leakage Current -10.0 +10.00 pA 0<Vin<Vec 
L 3-State Output/Data Bus Input Leakage Current -10.00 +100 pA 0<Vin<Vec 
loo Power Supply Current 100.0 mA Vou = 1.5V 
loup Darlington Drive Current -1.5 3.8 mA Rext = 3902 
Over specified temperature and voltage range. 
Capacitance Symbol Parameter Min’ Max Unit Test Condition 
Cc Clock Capacitance 10 pF Unmeasured 
: pins returned 
Cry Input Capacitance 5 pF ioareund 
Cour Output Capacitance 10 pF 
Over specitied temperature range; { = 1MH, 
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Product 


Zilog Specification 
March 198] 
Features @ Four independently programmable & Selectable positive or negative trigger 
counter/timer channels, each with a initiates timer operation. 
readable downcounter and a selectable @ Standard Z-80 Family daisy-chain interrupt 
16 or 256 prescaler. Downcounters are structure provides fully vectored, prioritized 
reloaded automatically at zero count. interrupts without external logic. The CTC 
a Three channels have Zero Count/Timeout may also be used as an interrupt controller. 
outputs capable of driving Darlington @ Interfaces directly to the Z-80 CPU or—for 
transistors. baud rate generation—to the Z-80 SIO. 
General The Z-80 CTC four-channel counter/timer each channel is programmed with two bytes; a 
Description can be programmed by system software for a third is necessary when interrupts are enabled. 
broad range of counting and timing applica- Once started, the CTC counts down, reloads 
tions. The four independently programmable its time constant automatically, and resumes 
channels of the Z-80 CTC satisfy common counting. Software timing loops are completely 
microcomputer system requirements for event eliminated. Interrupt processing is simplified 
counting, interrupt and interval timing, and because only one vector need be specified; the 
general clock rate generation. CTC internally generates a unique vector for 
System design is simplified because the CTC — each channel. 
connects directly to both the Z-80 CPU and the The Z-80 CTC requires a single +5 V power 
Z-80 SIO with no additional logic. In larger supply and the standard Z-80 single-phase 
systems, address decoders and buffers may be system clock. It is fabricated with n-channel 
required. silicon-gate depletion-load technology, and 
Programming the CTC is straightforward: packaged in a 28-pin plastic or ceramic DIP. 
CLK/TRGo 
. 2CITO, 
Pi CLKITRG, Ds 
BUS ZCITOs CHANNEL - 
SIGNALS Dy 
CLK/TRG2 Do 
2CiTO2 +5V 
buigine 6 é CLKITRGo 
ctc 3 280 CTC CLETRG 
CONTROL 8 tel he a1 fC] ciKtra, 
FROM CLKITRGs 
cS; 
Z80A CTC CSo 
CHAIN { AESET 
INTERRUPT cE 
CONTROL CLK 
CLK +5V GND 
Figure 1. Pin Functions Figure 2. Pin Assignments 
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Functional 
Description 


The Z-80 CTC has four independent counter/ 
timer channels. Each channel is individually 
programmed with two words:.a control word 
and a time-constant word. The control word 
selects the operating mode (counter or timer), 
enables or disables the channel interrupt, and 
selects certain other operating parameters. If 
the timing mode is selected, the control word 
also sets a prescaler, which divides the system 
clock by either 16 or 256. The time-constant 
word is a value from 1 to 256. 

During operation, the individual counter 
channel counts down from the preset time con- 
stant value. In counter mode operation the 
counter decrements on each of the CLK/TRG 
input pulses until zero count is reached. Each 
decrement is synchronized by the system 
clock. For counts greater than 256, more than 
one counter can be cascaded. At zero count, 
the down-counter is automatically reset with 
the time constant value. 

The timer mode determines time intervals as 
small as 4 ys (Z-80A) or 6.4 us (Z-80) without 
additional logic or software timing loops. Time 
intervals are generated by dividing the system 
clock with a prescaler that decrements 


a preset down-counter. 

Thus, the time interval is an integral mul- 
tiple of the clock period, the prescaler value 
(16 or 256) and the time constant that is preset 
in the down-counter. A timer is triggered auto- 
matically when its time constant value is pro- 
grammed, or by an external CLK/TRG input. 

Three channels have two outputs that occur 
at zero count. The first output is a zero- 
count/timeout pulse at the ZC/TO output. The 
fourth channel (Channel 3) does not have a 
ZC/TO output; interrupt request is the only 
output available from Channel 3. 

The second output is Interrupt Request 
(INT), which occurs if the channel has its 
interrupt enabled during programming. When 
the Z-80 CPU acknowledges Interrupt Request, 
the Z-80 CTC places an interrupt vector on the 
data bus. 

The four channels of the Z-80 CTC are fully 


_ prioritized and fit into four contiguous slots in 


a standard Z-80 daisy-chain interrupt struc- 
ture. Channel 0 is the highest priority and 
Channel 3 the lowest. Interrupts can be 
individually enabled (or disabled) for each of 
the four channels. 


Architecture 


The CTC has four major elements, as shown 
in Figure 3. 


m CPU bus I/O 

@ Channel control logic 
@ Interrupt logic 

m Counter/timer circuits 


CPU Bus I/O. The CPU bus J/O circuit 
decodes the address inputs, and interfaces the 
CPU data and control signals to the CTC for 
distribution on the internal bus. 


_ INTERNAL BUS: 


Internal Control Logic. The CTC internal 
control logic controls overall chip operating 
functions such as the chip enable, reset, and 
read/write logic. 


Interrupt Logic. The interrupt control logic 
ensures that the CTC interrupts interface prop- 
erly with the Z-80 CPU interrupt system. The 
logic controls the interrupt priority of the CTC 
as a function of the IEI signal. If IEI is High, 
the CTC has priority. During interrupt 


INTERNAL 
CONTROL 
LOGIC 


INTERRUPT 
Logic 


COUNTER! 
TIMER 
LoGic 


Figure 3. Functional Block Diagram 
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Architecture 
(Continued) 
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processing, the interrupt logic holds IEO Low, 
which inhibits the interrupt operation on lower 
priority devices. If the IEI input goes Low, 
priority is relinquished and the interrupt logic 
drives IEO Low. 

If a channel is programmed to request an 
interrupt, the interrupt logic drives IEO Low at 
the zero count, and generates an INT signal to 
the Z-80 CPU. When the Z-80 CPU responds 
with interrupt acknowledge (M1 and IORQ), 
then the interrupt logic arbitrates the CTC 
internal priorities, and the interrupt control 
logic places a unique interrupt vector on the 
data bus. 

If an interrupt is pending, the interrupt logic 
holds IEO Low. When the Z-80 CPU issues a 
Return From Interrupt (RETI) instruction, each 
peripheral device decodes the first byte 
(EDj¢). If the device has a pending interrupt, 
it raises IEO (High) for one M1 cycle. This 
ensures that all lower priority devices can 
decode the entire RETI instruction and reset 


properly. 


CHANNEL 
CONTROL 
Locic 


TIME 
CONSTANT 
REGISTER 


INTERNAL BUS 


DOWN: zc/To 


COUNTER 


cCLYTRA —————> 


CLOCK PRESCALER 


Figure 4. Counter/Timer Block Diagram 


Counter/Timer Circuits. The CTC has four 
independent counter/timer circuits, each con- 
taining the logic shown in Figure 4. 


Channel Control Logic. The channel control 
logic receives the 8-bit channel control word 
when the counter/timer channel is pro- 

grammed. The channel control logic decodes 


the control word and sets the following 
operating conditions: 


& Interrupt enable (or disable) 

f Operating mode (timer or counter) 

@ Timer mode prescaler factor (16 or 256) 

@ Active slope for CLK/TRG input 

@ Timer mode trigger (automatic or CLK/TRG 
input) 

@ Time constant data word to follow 

@ Software reset 


Time Constant Register. When the counter/ 
timer channel is programmed, the time con- 
stant register receives and stores an 8-bit time 
constant value, which can be anywhere from ] 
to 256 (0 = 256). This constant is automatic- 
ally loaded into the down-counter when the 
counter/timer channel is initialized, and subse- 
quently after each zero count. 


Prescaler. The prescaler, which is used only 
in timer mode, divides the system clock fre- 
quency by a factor of either 16 or 256. The 
prescaler output clocks the down-counter dur- 
ing timer operation. The effect of the prescaler 
on the down-counter is a multiplication of the 
system clock period by 16 or 256. The pre- 
scaler factor is programmed by bit 5 of the 
channel control word. 


Down-Counter. Prior to each count cycle, the 
down-counter is loaded with the time constant 
register contents. The counter is then 
decremented one of two ways, depending on 
operating mode: 


m@ By the prescaler output (timer mode) 
@ By the trigger pulses into the CLK/TRG 
input (counter mode) ; 


Without disturbing the down-count, the Z-80 
CPU can read the count remaining at any time 
by performing an I/O read operation at the 
port address assigned to the CTC channel. 
When the down-counter reaches the zero 
count, the ZC/TO output generates a positive- 
going pulse. When the interrupt is enabled, 
zero count also triggers an interrupt request 
signal (INT) from the interrupt logic. 
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Programming 


Each Z-80 CTC channel must be pro- 
grammed prior to operation. Programming 
consists of writing two words to the I/O port 
that corresponds to the desired channel. The 
first word is a control word that selects the 
operating mode and other parameters; the 
second word is a time constant, which is a 
binary data word with a value from 1 to 256. A 
time constant word must be preceded by a 
channel control word. 

After initialization, channels may be 
reprogrammed at any time. If updated control 
and time constant words are written to a chan- 
nel during the count operation, the count con- 
tinues to zero before the new time constant is 
loaded into the counter. 

If the interrupt on any Z-80 CTC channel is 
enabled, the programming procedure should 
also include an interrupt vector. Only one vec- 
tor is required for all four channels, because 
the interrupt logic automatically modifies the 
vector for the channel requesting service. 

A control word is identified by a 1 in bit 0. 
A 0 in bit 2 indicates a time constant word is to 
follow. Interrupt vectors are always addressed 
to Channel 0, and identified by a 0 in bit 0. 


Addressing. During programming, channels 
are addressed with the channel select pins CS) 
and CS9. A 2-bit binary code selects the 
appropriate channel as shown in the following 
table. 


Channel CS) CSo 
0 0 0 
] 0 ] 
2 ] 0 
3 l ] 


Reset. The CTC has both hardware and soft- 
ware resets. The hardware reset terminates all 
down-counts and disables all CTC interrupts 
by resetting the interrupt bits in the control 
registers. In addition, the ZC/TO and Interrupt 
outputs go inactive, IEO reflects IEI, and 


Do-D7 go to the high-impedance state. All 
channels must be completely reprogrammed 
after a hardware reset. 

The software reset is controlled by bit 1 in 
the channel control word. When a channel 
receives a software reset, it stops counting. . 
When a software reset is used, the other bits in 
the control word also change the contents of 
the channel control register. After a software 
reset a new time constant word must be written 
to the same channel. 

If the channel control word has both bits D) 
and D2 set to 1, the addressed channel stops 
operating, pending a new time constant word. 
The channel is ready to resume after the new 
constant is programmed. In timer mode, if 
D3 = 0, operation is triggered automatically 
when the time constant word is loaded. 


Channel Control Word Programming. The 
channel control word is shown in Figure 5. It 
sets the modes and parameters described 
below. 


Interrupt Enable. D7 enables the interrupt, so 
that an interrupt output (INT) is generated at 
zero count. Interrupts may be programmed in 
either mode and may be enabled or disabled 
at any time. 


Operating Mode. Dg selects either timer or 
counter mode. 


Prescaler Factor. (Timer Mode Only). Ds 
selects factor—either 16 or 256. 


Trigger Slope. D4 selects the active edge or 
slope of the CLK/TRG input pulses. Note that 
reprogramming the CLK/TRG slope during 
operation is equivalent to issuing an active 
edge. If the trigger slope is changed by a con- 
trol word update while a channel is pending 
operation in timer mode, the result is the same 
as a CLK/TRG pulse and the timer starts. 
Similarly, if the channel is in counter mode, 
the counter decrements. 


INTERRUPT e 
1 ENABLES INTERRUPT 
0 DISABLES INTERRUPT 
MODE 


0 SELECTS TIMER MODE 
1 SELECTS COUNTER MODE 


PRESCALER VALUE* 
1 = VALUE OF 256 
0 = VALUE OF 16 


CLK/TRO EDGE SELECTION 
0 SELECTS FALLING EOGE 
1 SELECTS RISING EDGE 


L CONTROL OR VECTOR 
0 = VECTOR 
1 = CONTROL WORD 
RESET 


0 = CONTINUED OPERATION 
1 = SOFTWARE RESET 


TIME CONSTANT 
0 = NO TIME CONSTANT FOLLOWS 
1 = TIME CONSTANT FOLLOWS 


TIMER TRIGGER* 

0 = AUTOMATIC IRIGGER WHEN 
TIME CONSTANT 1S LOADED 

1 = CLK/TRG PULSE STARTS TIMER 


*TIMER MODE ONLY 


Figure 5. Channel Control Word 
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Programming Trigger Mode (Timer Mode Only). D3 selects 


(Continued) 


the trigger mode for timer operation. When D3 
is reset to 0, the timer is triggered automatic- 
ally. The time constant word is programmed 
during an I/O write operation, which takes one 
machine cycle. At the end of the write opera- 
tion there is a setup delay of one clock period. 
The timer starts automatically (decrements) on 
the rising edge of the second clock pulse (T2) 
of the machine cycle following the write opera- 
tion. Once started, the timer runs contin- 
uously. At zero count the timer reloads 
automatically and continues counting without 
interruption or delay, until stopped by a reset. 

When D3 is set to 1, the timer is triggered 
externally through the CLK/TRG input. The 
time constant word is programmed during an 
I/O write operation, which takes one machine 
cycle. The timer is ready for operation on the 
rising edge of the second clock pulse (T2) of 
the following machine cycle. Note that the first 
timer decrement follows the active edge of the 
CLK/TRG pulse by a delay time of one clock 
cycle if a minimum setup time to the rising 
edge of clock is met. If this minimum is not 
met, the delay is extended by another clock 
period. Consequently, for immediate trigger- 
ing, the CLK/TRG input must precede Tz by 
one clock cycle plus its minimum setup time. If 
the minimum time is not met, the timer will 
start on the third clock cycle (T3). 

Once started the timer operates contin- 
uously, without interruption or delay, until 
stopped by a reset. 


Time Constant to Follow. A 1 in D2 indicates 
that the next word addressed to the selected 
channel is a time constant data word for the 
time constant register. The time constant. word 
may be written at any time. 

A 0 in D2 indicates no time constant word is 
to follow. This is ordinarily used when the 
channel is already in operation and the new 
channel control word is an update. A channel 
will not operate without a time constant value. 
The only way to write a time constant value is 
to write a control word with D> set. 


Figure 6. Time Constant Word 


Software Reset. Setting D) to 1 causes a soft- 
ware reset, which is described in the Reset 
section. 


Control Word. Setting Do to 1 identifies the 
word as a control word. 


Time Constant Programming. Before a chan- 
nel can start counting it must receive a time 
constant word from the CPU. During program- 
ming or reprogramming, a channel control 
word in which bit 2 is set must precede the 
time constant word to indicate that the next 
word is a time constant. The time constant 
word can be any value from | to 256 (Figure 
6). Note that 00, is interpreted as 256. 

In timer mode, the time interval is controlled 
by three factors: 


m The system clock period (¢) 


t The prescaler factor (P), which multiplies 
the interval by either 16 or 256 


@ The time constant (T), which is programmed 
into the time constant register 


Consequently, the time interval is the pro- 
duct of 6x PxT. The minimum timer resolu- 
tion is 16x @ (4 ps with a 4 MHz clock). The 
maximum timer interval is 256 x @ x 256 (16.4 ms 
with a 4 MHz clock). For longer intervals 
timers may be cascaded. 


Interrupt Vector Programming. If the Z-80 
CTC has one or more interrupts enabled, it 
can supply interrupt vectors to the Z-80 CPU. 
To do so, the Z-80 CTC must be pre-pro- 
grammed with the most-significant five bits of 
the interrupt vector. Programming consists of 
writing a vector word to the I/O port cor- 
responding to the Z-80 CTC Channel 0. Note 
that Do of the vector word is always zero, to 
distinguish the vector from a channel control 
word. D, and D2 are not used in programming 
the vector word. These bits are supplied by 
the interrupt logic to identify the channel 
requesting interrupt service with a unique 
interrupt vector (Figure 7). Channel 0 has the 
highest priority. 


LD, [Bx] D5 [O, [Ds] 02 {0s | | 
| | L 0 = INTERRUPT VECTOR WORD 
V7-N3 1 = CONTROL WORD 


SUPPLIED 
BY USER 
CHANNEL IDENTIFIER 
(AUTOMATICALLY INSERTED 
BY CTC) 
0 0 = CHANNEL O 
0 1 = CHANNEL 1 
1 0 = CHANNEL 2 
1 1 = CHANNEL 3 


Figure 7. Interrupt Vector Word 


2041-0160, G161 


63 


OLD 08Z 


Pin 
Description 


CE. Chip Enable (input, active Low). When 
enabled the CTC accepts control words, inter- 
rupt vectors, or time constant data words from 
the data bus during an I/O write cycle; or 
transmits the contents of the down-counter to 
the CPU during an I/O read cycle. In most 
applications this signal is decoded from the 
eight least significant bits of the address bus 
for any of the four I/O port addresses that are 
mapped to the four counter-timer channels. 
CLK. System Clock (input). Standard single- 
phase Z-80 system clock. 
CLK/TRGp-CLK/TRG3. External Clock/Timer 
Trigger (input, user-selectable active High or 
Low). Four pins corresponding to the four Z-80 
CTC channels. In counter mode, every active 


edge on this pin decrements the down-counter. 


In timer mode, an active edge starts the timer. 


CSo-CS;. Channe! Select (inputs active High). 
Two-bit binary address code selects one of the 
four CTC channels for an I/O write or read 
(usually connected to Ag and A)). 


Do-D7. System Data Bus (bidirectional, 
3-state). Transfers all data and commands 


between the Z-80 CPU and the Z-80 CTC. 


SYSTEM 
BUSES 


ZCITO2_ INT 
1EO 


Figure 8. A Typical Z-80 Environment 


TEI. Jnterrupt Enable In (input, active High). 
A High indicates that no other interrupting 
devices of higher priority in the daisy chain 


are being serviced by the Z-80 CPU. 


IEO. Interrupt Enable Out (output, active 
High). High only if IEI is High and the Z-80 
CPU is not servicing an interrupt from any 
Z-80 CTC channel. IEO blocks lower priority 
devices from interrupting while a higher 
priority interrupting device is being serviced. 


INT. Interrupt Request (output, open drain, 
active Low). Low when any Z-80 CTC channel 
that has been programmed to enable interrupts 
has a zero-count condition in its down-counter. 


TORQ. Input/Output Request (input from CPU, 
active Low). Used with CE and RD to transfer 
data and channel contro] words between the 
Z-80 CPU and the Z-80 CTC. During a write 
cycle, IORQ and CE are active and RD 
inactive. The Z-80 CTC does not receive a 
specific write signal; rather, it internally 
generates its own from the inverse of an active 
RD signal. In a read cycle, IORQ, CE and RD 
are active; the contents of the down-counter 
are read by the Z-80 CPU. If IORQ and M1 are 
both true, the CPU is acknowledging an inter- 
rupt request, and the highest priority inter- 
rupting channel places its interrupt vector on 
the Z-80 data bus. 


Ml. Machine Cycle One (input from CPU, 
active Low). When M1 and IOROQ are active, 
the Z-80 CPU is acknowledging an interrupt. 
The Z-80 CTC then places an interrupt vector 
on the data bus if it has highest priority, and if 
a channel has requested an interrupt (INT). 


RD. Read Cycle Status (input, active Low). 
Used in conjunction with IORO and CE to 
transfer data and channel control words 


between the Z-80 CPU and the Z-80 CTC. 


RESET. Reset (input active Low). Terminates 
all down-counts and disables all interrupts by 
resetting the interrupt bits in all control 
registers; the ZC/TO and the Interrupt outputs 
go inactive; IEO reflects IE]; Do-D7 go to the 
high-impedance state. 


ZC/TOp-ZC/TO2. Zero Count/Timeout (output, 
active High). Three ZC/TO pins corresponding 
to Z-80 CTC channels 2 through 0 (Channel 3 
has no ZC/TO pin). In both counter and timer 
modes the output is an active High pulse when 
the down-counter decrements to zero. 
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Timing | Read Cycle Timing. Figure 9 shows read 


cycle timing. This cycle reads the contents of a 


down-counter without disturbing the count. 


During clock cycle Tz, the Z-80 CPU initiates a 


read cycle by driving the following inputs 
Low: RD, IORQ, and CE. A 2-bit binary code 
at inputs CS); and CSp selects the channel to 
be read. M1 must be High to distinguish this 
cycle from an interrupt acknowledge. No addi- 
tional wait states are allowed. 


ty T2 Twa T3 T 


Figure 9. Read Cycle Timing 


Write Cycle Timing. Figure 10 shows write 
cycle timing for loading control, time constant 
or vector words. 

The CTC does not have a write signal input, 
so it generates one internally when the read 
(RD) input is High during T,. During T2 
IORQ and CE inputs are Low. M! must be 
High to distinguish a write cycle from an inter- 
rupt acknowledge. A 2-bit binary code at 
inputs CS; and CS selects the channel to be 
addressed, and the word being written is 
placed on the Z-80 data bus. The data word is 


Figure 10. Write Cycle Timing 
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latched into the appropriate register with the 
rising edge of clock cycle Twa. No additional 
wait states are allowed. 


CLKJTRAG 


INTERNAL 
TIMER a, AO 


Figure 11. Timer Mode Timing 


Timer Operation. In the timer mode, a 
CLK/TRG pulse input starts the timer (Figure 
11) on the second succeeding rising edge of 
CLK. The trigger pulse is asynchronous. and it 
must have a minimum width. A minimum lead 
time (210 ns) is required between the active 
edge of the CLK/TRG and the next rising edge 
of CLK to enable the prescaler on the follow- 
ing clock edge. If the CLK/TRG edge occurs 
closer than this, the initiation of the timer 
function is delayed one clock cycle. This cor- 
responds to the startup timing discussed in the 
programming section. The timer can also be 
started automatically if so programmed by the 
channel control word. 


L—] 

CLKITRG an 
INTERNAL NY 
COUNTER ea 

zCITO 


Figure 12. Counter Mode Timing 


Counter Operation. In the counter mode, the 
CLK/TRG pulse input decrements the down- 
counter. The trigger is asynchronous, but the 
count is synchronized with CLK. For the 
decrement to occur on the next rising edge of 
CLK, the trigger edge must precede CLK by a 
minimum lead time as shown in Figure 12. If 
the lead time is less than specified, the count 
is delayed by one clock cycle. The trigger 
pulse must have a minimum width, and the 
trigger period must be at least twice the clock 
period. 

The ZC/TO output occurs immediately after 
zero count, and follows the rising CLK edge. 
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Interrupt 
Operation 


+5V 


HIGHEST PRIORITY 
DEVICE 


The Z-80 CTC follows the Z-80 system inter- 
rupt protocol for nested priority interrupts and 
return from interrupt, wherein the interrupt 
priority of a peripheral is determined by its 
location in a daisy chain. Two lines—IEI and 
IEO—in the CTC connect it to the system daisy 
chain. The device closest to the +5 V supply 
has the highest priority (Figure 13). For addi- 
tional information on the Z-80 interrupt struc- 
ture, refer to the Z-80 CPU Product Specifica- 
tion and the Z-80 CPU Technical Manual. 


LOWEST PRIORITY 
DEVICE 


DEVICE 1 DEVICE 2 DEVICE 3 
HI HI HI HI! 


DEVICE 0 


Figure 13. Daisy-Chain Interrupt Priorities 


Within the Z-80 CTC, interrupt priority is 
predetermined by channel number: Channel 0 
has the highest priority, and Channel 3 the 
lowest. If a device or channel is being serviced 
with an interrupt routine, it cannot be inter- 
rupted by a device or channel with lower 
priority until service is complete. Higher 
priority devices or channels may interrupt the 
servicing of lower priority devices or channels. 

A Z-80 CTC channel may be programmed to 
request an interrupt every time its down- 
counter reaches zero. Note that the CPU must 
be programmed for interrupt mode 2. Some 
time after the interrupt request, the CPU sends 
an interrupt acknowledge. The CTC interrupt 
control logic determines the highest priority 
channel that is requesting an interrupt. Then, 
if the CTC IEI input is High (indicating that it 
has priority within the system daisy chain) it 
places an 8-bit interrupt vector on the system 
data bus. The high-order five bits of this vector 


Figure 14. Interrupt Acknowledge Timing 


were written to the CTC during the program- 
ming process; the next two bits are provided 
by the CTC interrupt control logic as a binary 
code that identifies the highest priority chan- 
nel requesting an interrupt; the low-order bit 
is always zero. 


Interrupt Acknowledge Timing. Figure 14 


' shows interrupt acknowledge timing. After an 


interrupt request, the Z-80 CPU sends an inter- 
rupt acknowledge (M1 and IORQ). All chan- 
nels are inhibited from changing their inter- 
rupt request status when M1 is active—about 
two clock cycles earlier than IORQ. RD is 
High to distinguish this cycle from an instruc- 
tion fetch. 

The CTC interrupt logic determines the 
highest priority channel requesting an inter- 
rupt. If the CTC interrupt enable input (IEI) is 
High, the highest priority interrupting channel 
within the CTC places its interrupt vector on 
the data bus when IORQ goes Low. Two wait 
states (Twa) are automatically inserted at this 
time to allow the daisy chain to stabilize. Addi- 
tional wait states may be added. 


Return from Interrupt Timing. At the end of 
an interrupt service routine the RETI (Return 
From Interrupt) instruction initializes the daisy 
chain enable lines for proper control of nested 
priority interrupt handling. The CTC decodes 
the 2-byte RETI code internally and determines 
whether it is intended for a channel being ser- 
viced. Figure 15 shows RETI timing. 

If several Z-80 peripherals are in the daisy 
chain, IEI settles active (High) on the chip 
currently being serviced when the opcode 
ED jg is decoded. If the following opcode is 
4D, the peripheral being serviced is released 
and its IEO becomes active. Additional wait 
states are allowed. 


Figure 15. Return From Interrupt Timing 
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11.4 Appendex D - Floppy Disk controller .... 


ESVTERW BIGITAL 


C GF R P OQ R 


FEATURES 


@ TWO VFO CONTROL SIGNALS 


SOFT SECTOR FORMAT COMPATIBILITY 
AUTOMATIC TRACK SEEK WITH 
VERIFICATION 
@ ACCOMMODATES SINGLE AND DOUBLE 
DENSITY. FORMATS 
IBM 3740 Single Density (FM) 
{BM System 34 Double Density (MFM) 
READ MODE 
Single/Multiple Sector Read with Automatic 
Search or Entire Track Read 
Selectable 128 Byte or Variable length Sector 
WRITE MODE 
Single/Multiple Sector Write with Automatic 
Sector Search 
Entire Track Write for Diskette Formatting 


SYSTEM COMPATIBILITY 

Double Buffering of Data 8 Bit Bi-Directional 
Bus for Data, Control and Status 

DMA or Programmed Data Transfers 

All Inputs and Outputs are TTL Compatible 

On-Chip Track and Sector Registers/Comprehensive 
Status Information 
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‘I791/3SRG 1796/7= SSO 
*"1793/7 TRUE BUS 


PIN CONNECTIONS 


Ei eee opey Dish oumatien Contolen amily 


A TF Tf 


@ PROGRAMMABLE CONTROLS 
Selectable Track to Track Stepping Time 
Side Select Compare 

© WRITE PRECOMPENSATION 

e WINDOW EXTENSION 

e INCORPORATES ENCODING/DECODING 

AND ADDRESS MARK CIRCUITRY 
e@ FD1792/4 IS SINGLE DENSITY ONLY 
e FD1795/7 HAS A SIDE SELECT OUTPUT 


179X-02 FAMILY CHARACTERISTICS 


3 
4 
= 


[Single Density (FM)__ | X_| 
[Double Density (MFM) [x | 
True DataBus [| 

ea 


Side Selection Output 


APPLICATIONS 


FLOPPY DISK DRIVE INTERFACE 

SINGLE OR MULTIPLE DRIVE CONTROLLER/ 
FORMATTER 

NEW MINI-FLOPPY CONTROLLER 


RAW READ 


179X 


FLOPPY OISK 
CONTROLLER 
FORMATTER 


MOrnUIMaAZ— KRH-O <VIOLFMT 


ONE SHOT 
(IF USED) 
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GENERAL DESCRIPTION 

The FD179X are MOS LSI devices which perform the 
functions of a Floppy Disk Formatter/Controller in 
a single chip implementation. The FD179X, which 
can be considered the end result of both the FD1771 
and FD1781 designs, is IBM 3740 compatible in 
single density mode (FM) and System 34 compatible 
in Double Density Mode (MFM). The FD179X con- 
tains all the features of its predecessor the FD1771, 
plus the added features necessary to read/write and 
format a double density diskette. These include ad- 
dress mark detection, FM and MFM encode and de- 
code logic, window extension, and write precompen- 
sation. In order to maintain compatibility, the FD1771, 
FD1781, and FD179X designs were made as close as 
possible with the computer interface, instruction set, 
and I/O registers being identical. Also, head load 


PIN OUTS 


NO CONNECTION 


MASTER RESET 


CHIP SELECT 


READ ENABLE 


REGISTER SELECT 
LINES 


DATA ACCESS LINES DALC-DAL7 


PIN 
NUMBER en|_rmne |g SYMBOL FUNCTION 


control is identical. In each case, the actual: pin as- 
signments vary by only a few pins from any one to 
another. 


The processor interface consists of an 8-bit bi- 
directional bus for data, status, and control word 
transfers. The FD179X is set up to operate on a mul- 
tiplexed bus with other bus-oriented devices. 


The FD179X is fabricated in N-channel Silicon Gate 
MOS technology and is TTL compatible on all inputs 
and outputs. The 1793 is identical to the 1791 except 
the DAL lines are TRUE for systems that utilize true 
data busses. ; 

The 1795/7 has a side select output for controlling dou- 
ble sided drives, and the 1792 and 1794 are “Single 
Density Only” versions of the 1791 and 1793. On these 
devices, DDEN must be left open. 


Pin 1 is internally connected to a back bias 
generator and must be left open by the user. 


A logic low on this input resets the device and 
loads HEX 03 into the command register. The Not 
Ready (Status Bit 7) is reset during MR ACTIVE. 
When MR is brought to a logic high a RESTORE 
Command is executed, regardless of the state of 
the Ready signal from the drive. Also, HEX 01 is 
loaded into sector register. 


Ground 
+5V +5% 
+12V +5% 


A logic low on this input gates data on the DAL 
into the selected register when CS is low. 


A logic low on this input selects the chip and ena- 
bles computer communication with the device. 


A logic low on this input controls the placement of 
data from a selected register on the DAL when CS 
is low. 


These inputs select the register to_receive/ 
transfer data on the DAL lines under RE and WE 
control: 


At AO RE WE 

0 0 Status Reg Command Reg 
0 1 Track Reg Track Reg 

1 0 Sector Reg Sector Reg 

1 1 Data Reg Data Reg 


Eight bit inverted Bidirectional bus used for trans- 
fer of data, control, and status. This bus is receiver 
enabled by WE or transmitter enabled by RE. 


This input requires a free-running square wave 
clock for internal timing reference, 2 MHz for 8” 
drives, 1 MHz for mini-drives. 


PIN 
NUMBER SYMBOL 


DATA REQUEST 


39 INTERRUPT 

REQUEST 
FLOPPY DISK INTERFACE: 

15 STEP 

16 DIRECTION 

17 EARLY 

18 LATE 

22 TEST 

23 HEAD LOAD TIMING 

25 READ GATE (1791/3) 

25 SIDE SELECT OUTPUT 

(1795, 1797) 

26 READ CLOCK 

27 RAW READ 

28 HEAD LOAD 

29 TRACK GREATER 
THAN 43 
WRITE GATE 


This open drain output indicates that the DR-con- 
tains assembled data in Read operations, or the 
DR is empty in Write operations. This signal is 
reset when serviced by the computer through 
reading or loading the DR in Read or Write opera- 
tions, respectively. Use 10K pull-up resistor to +5. 


This open drain output is set at the completion of any 
command and is reset when the STATUS register is 


read or the command register is written to. Use 10K 
pull-up resistor to +5. 


The step output contains a pulse for each step. 


Direction Output is active high when stepping in, 
active low when stepping out. 


Indicates that the WRITE DATA pulse occurring 
while Early is active (high) should be shifted early 
for write precompensation. 


Indicates that the write data pulse occurring while 
Late is active (high) should be shifted late for write 
precompensation. 


This input is used for testing purposes only and 
should be tied to +5V or left open by the user un- 
less interfacing to voice coil actuated motors. 


When a logic high is found on the HLT input the 
head is assumed to be engaged. 


A high level on this output indicates to the data 
separator circuitry that a field of zeros (or ones) 
has been encountered, and is used for synchroni- 
zation. 


The logic level of the Side Select Output is directly 
controlled by the ‘S’ flag in Type II or Il! commands. 
When S = 1, SSO is set to a logic 1. When S = 0, 
SSO is set to a logic 0. The Side Select Output is only 
updated at the beginning of a Type It or Ill command. 
It is forced to a logic 0 upon! a MASTER RESET 
condition. 

A nominal square-wave clock signal derived from 
the data stream must be provided to this input. 
Phasing (i.e. RCLK transitions) relative to RAW 
READ is important but polarity (RCLK high or low) 
is not. 


The data input signal directly from the drive. This 
input shall be a negative pulse for each recorded 
flux transition. 

The HLD output controls the loading of the 
Read-Write head against the media. 

This output informs the drive that the Read/Write 
head is positioned between tracks 44-76. This output 
is valid only during Read and Write Commands. 
This output is made valid before writing is to be 
performed on the diskette. 


RAW READ 


HLD 


TG43 


WG 
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PIN 
NUMBER en| _ewmaae | SYMBOL FUNCTION 


WRITE DATA 


WF/VFOE 


WRITE FAULT 
VFO ENABLE 


TRACK 00 
INDEX PULSE 


WRITE PROTECT 


DOUBLE DENSITY 


ORGANIZATION 

The Floppy Disk Formatter block diagram is illus- 
trated on page 5. The primary sections include the 
parallel processor interface and the Floppy Disk inter- 
face. 


Data Shift Register—This 8-bit register assembles 
serial data from the Read Data input (RAW READ) 
during Read operations and transfers serial data to 
the Write Data output during Write operations. 


Data Register—This 8-bit register is used as a hold- 
ing register during Disk Read and Write operations. 
In Disk Read operations the assembied data byte is 
_ transferred in parallel to the Data Register from the 
* ‘Data Shift Register. In Disk Write operations informa- 
tion is transferred in paralle! from the Data Register 
to the Data Shift Register. 


A 250 ns (MFM) or 500 ns (FM) pulse per flux 
transition. WD contains the unique Address marks 
as well as data and clock in both FM and MFM 
formats. 

This input indicates disk readiness and is sampled 
for a logic high before Read or Write commands 
are performed. If Ready is low the Read or Write 
operation is not performed and an interrupt is 
generated. Type | operations are performed re- 
gardiess of the state of Ready. The Ready input 
appears in inverted format as Status Register bit 
7. 


This is a bi-directional signal used to signify writing 
faults at the drive, and to enable the external PLO 
data separator. When WG = 1, Pin 33 functions as 
a WF input. if WF = 0, any write command will im- 
mediately be terminated. When WG = 0, Pin 33 func- 
tions as a VFOE output. VFOE will go low during a 
read operation after the head has loaded and settled 
(HLT = 1). On the 1795/7, it will remain low until the 
last bit of the second CRC byte in the ID field. VFOE 
will then go high until 8 bytes (MFM) or 4 bytes (FM) 
before the Address Mark. It will then go active until 
the last bit of the second CRC byte of the Data Field. 
On the 1791/3, VFOE will remain low until the end of 
the Data Field. 


This input informs the FD179X that the Read/Write 
head is positioned over Track 00. 


This input informs the FD179X when the index hole 
is encountered on the diskette. 


This input is sampled whenever a Write Command 
is received. A logic low terminates the command 
and sets the Write Protect Status bit. 


This pin selects either single or double density op- 
eration. When DDEN = 0, double density is 
selected. When DDEN = 1, single density is 
selected. This line must be left open on the 1792/4 


When executing the Seek command the Data Regis- 
ter holds the address of the desired Track position. 
This register is loaded from the DAL and gated onto 
the DAL under processor control. 


Track Register—This 8-bit register holds the track 
number of the current Read/Write head position. It is 
incremented by one every time the head is stepped in 
(towards track 76) and decremented by one when the 
head is stepped out (towards track 00). The contents 
of the register are compared with the recorded track 
number in the ID field during disk Read, Write, and 
Verify operations. The Track Register can be loaded 
from or transferred to the DAL. This Register should 
not be loaded when the device is busy. 
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FD179X BLOCK DIAGRAM 


Sector Register (SR)—This 8-bit register holds the 
address of the desired sector position. The contents 
of the register are compared with the recorded sector 
number in the ID field during disk Read or Write op- 
erations. The Sector Register contents can be loaded 
from or transferred to the DAL. This register should 
not be loaded when the device is busy. 


Command Register (CR)—This 8-bit register holds 
the command presently being executed. This register 
should not be loaded when the device is busy unless 
the new command is a force interrupt. The command 
register can be loaded from the DAL, but not read 
onto the DAL. 

Status Register (STR)—This 8-bit register holds de- 
vice Status information. The meaning of the Status 
bits is a function of the type of command previously 
executed. This register can be read onto the DAL, 
but not loaded from the DAL. 


CRC Logic—This logic is used to check or to gener- 
ate the 16-bit Cyclic Redundancy Check (CRC). The 
polynomial is: G(x) = x'§ + x'? + x5 +1. 
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The CRC includes all information starting with the 
address mark and up to the CRC characters. The 
CRC register is preset to ones prior to data being 
shifted through the circuit. 


Arithmetic/Logic Unit (ALU)—The ALU is a serial 
comparator, incrementer, and decrementer and is 
used for register modification and comparisons with 
the disk recorded ID field. 


Timing and Control—All computer and Floppy Disk 
Interface controls are generated through this logic. 
The internal device timing is generated from an ex- 
ternal crystal clock. 

The FD1791/3 has two different_modes of_operation 
according to the state of DDEN. When DDEN =0 
double density (MFM) is assumed. When =1, 
single density (FM) is assumed. 


AM Detector—The address mark detector detects 
ID, data and index address marks during read and 
write operations. 


Ny Z2ZO-AOMo 


PROCESSOR INTERFACE 


The interface to the processor is accomplished 
through the eight Data Access Lines (DAL) and as- 
sociated control signals. The are used to trans- 
fer Data, Status, and Control words out of, or into the 
FD179X. The DAL are three state buffers that are en- 
abled as output drivers when Chip Select (CS) and 


Read Enable (RE) are active (low logic state) or_act 
as input receivers when CS and Write Enable (WE) 
are active. 


When transfer of data with the Floppy Disk Controller 
is required by the host processor, the device address 
is decoded and CS is made low. The address bits A1 
and AO, combined with the signals RE during a Read 
operation or WE during a Write operation are inter- 
preted as selecting the following registers: 


A1-A0 READ (RE) WRITE (WE) 


0 0 Status Register Command Register 
Oo 1 Track Register Track Register 

1 0 Sector Register Sector Register 

1 1 Data Register Data Register 


During Direct Memory Access (DMA) types of data 
transfers between the Data Register of the FD179X 
and the processor, the Data Request (DRQ) output is 
used in Data Transfer control. This signal also ap- 
pears as status bit 1 during Read and Write opera- 
tions. 

On Disk Read operations the Data Request is acti- 
vated (set high) when an assembled serial input byte 
is transferred in parallel to the Data Register. This bit 
is cleared when the Data Register is read by the pro- 
cessor. If the Data Register is read after one or more 
characters are lost, by having new data transferred 
into the register prior to processor readout, the Lost 
Data bit is set in the Status Register. The Read op- 
eration continues until the end of sector is reached. 


On Disk Write operations the data Request is acti- 
vated when the Data Register transfers its contents 
to the Data Shift Register, and requires a new data 
byte. It is reset when the Data Register is loaded 
with new data by the processor. If new data is not 
loaded at the time the next serial byte is required by 
the Floppy Disk, a byte of zeroes is written on the 
diskette and the Lost Data bit is set in the Status Re- 
gister. 


At the completion of every command an INTRQ is 
generated. INTRQ is reset by either reading the 
Status register or by loading the command register 
with a new command. In addition, INTRQ is gener- 
ated if a Force Interrupt command condition is met. 


FLOPPY DISK INTERFACE 


The 179X has two modes of operation according to the 
state of DDEN (Pin 37). When = 1, single density 
is selected. In either case, the CLK input (Pin 24) is at 
2 MHz. However, when interfacing with the mini-floppy, 
the CLK input is set at 1 MHz for both single density and 
double density. When the clock is at 2 MHz, the stepping 
rates of 3, 6, 10, and 15 ms are obtainable. When CLK 
equals 1 MHz these times are doubled. 


HEAD POSITIONING 


Five commands cause positioning of the Read-Write 
head (see Command Section). The period of each 
positioning step is specified by the r field in bits 1 and 
0 of the command word. After the last directional 
step an additional 15 milliseconds of head settling 
time takes place if the Verify flag is set in Type | 
commands. Note that this time doubles to 30 ms for 
a 1 MHz clock. If TEST = 0, there is zero settling 
time. There is also a 15 ms head settling time if the E 
flag is set in any Type II or Ill command. 


The rates (shown in Table 1) can be applied to a 
Step-Direction Motor through the device interface. 


Step—A 2 us (MFM) or 4 us (FM) pulse is provided 
as an output to the drive. For every step pulse is- 
sued, the drive moves one track location in a direc- 
tion determined by the direction output. 


Direction (DIRC)—The Direction signal is active high 
when stepping in and low when stepping out. The Di- 
rection signal is valid 12 ys before the first stepping 
pulse is generated. 


When a Seek, Step or Restore command is executed 
an optional verification of Read-Write head position 
can be performed by setting bit 2 (V = 1) in the 
command word to a logic 1. The verification operation 
begins at the end of the 15 millisecond settling time 
after the head is loaded against the media. The track 
number from the first encountered ID Field is com- 
pared against the contents of the Track Register. If 
the track numbers compare and the ID Field Cyctic 
Redundancy Check (CRC) is correct, the verify oper- 
ation is complete and an INTRQ is generated with no 
errors. The FD179X must find an ID field with correct 
track number and correct CRC within 5 revolutions of 
the media; otherwise the seek error is set and an 
INTRQ is generated. 


Table 1. STEPPING RATES 


CLK 2MHz 2 MHz 1 MHz 1 MHz 2 MHz 1 MHz 


DDEN 0 1 0 1 x 
TEST=1 


R1RO TEST=1 


TEST=1 TEST=1 TEST=0 
0.0 3ms 
01 6 ms 
10 10 ms 


11 15 ms 


The Head Load (HLD) output controls the movement 
of the read/write head against the media. HLD is ac- 
tivated at the beginning of a Type | command if the h 
flag is set (h = 1), at the end of the Type | command 
if the verify flag (V = 1), or upon receipt of any Type 
il or tll command. Once HLD is active it remains ac- 
tive until either a Type | command is received with 
(h = 0 and V = 0); or if the FD179xX< is in an idle state 
(non-busy) and 15 index pulses have occurred. 
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Head Load Timing (HLT) is an input to the FD179X 
which isused for the head engage time. When 
HLT = 1, the FD179X assumes the head is com- 
pletely engaged. The head engage time is typically 
30 to 100 ms depending on drive. The low to high 
transition on HLD is typically used to fire a one shot. 
The output of the one shot is then used for HLT and 
supplied as an input to the FD179X. 


HLO f evel 


|~——+0 To 100ms ——-} 
Foe 4 
i] 


HLT (FROM ONE SHOT) 


HEAD LOAD TIMING 


When both HLD and HLT are true, the FD179X will 
then read from or write to the media. The “and” of 
HLD and HLT appears as a status bit in Type | 
status. 


In summary for the Type | commands: if h = 0 and 
V = 0, HLDis reset. Ifh = 1 and V = 0, HLDis set at the 
beginning of the command and HLT is not sampled nor 
is there an internal 15 ms delay. If h = 0 and V = 1, 
HLD is set near the end of the command, an internal 
15 ms occurs, and the FD179X waits for HLT to be 
true. Ifh = 1 and V = 1, HLD is set at the beginning 
of the command. Near the end of the command, after 
all the steps have been issued, an internal 15 ms 
delay occurs and the FD179X then waits for HLT to 
occur. 


For Type II and II commands with E flag off, HLD is 
made active and HLT is sampled until true. With E 
flag on, HLD is made active, an internal 15 ms delay 
occurs and then HLT is sampled until true. 


DISK READ OPERATIONS 


Sector lengths of 128, 256, 512 or 1024 are obtaina- 
ble in either FM or MFM formats. For FM, DDEN 
should be placed to logical “1. For MFM formats, 
DDEN should be placed to a logical “0."" Sector 
lengths are determined at format time by a special 
byte in the “ID” field. If this Sector length byte in the 
ID field is zero, then the sector length is 128 bytes. If 
01 then 256 bytes. If 02, then 512 bytes. if 03, then 
the sector length is 1024 bytes. The number of sec- 
tors per track as far as the FD179X is concerned can 
be from 1 to 255 sectors. The number of tracks as far 
as the FD179X is concerned is from 0 to 255 tracks. 
For IBM 3740 compatibility, sector lengths are 128 
bytes with 26 sectors per track. For System 34 com- 
patibility (MFM), sector lengths are 256 bytes/sector 
with 26 sectors/track; or lengths of 1024 bytes/sector 
with 8 sectors/track. (See Sector Length Table.) 


For read operations, the FD179X requires RAW 
READ Data (Pin 27) signal which is a 250 ns pulse 
per flux transition and a Read clock (RCLK) signal to 
indicate flux transition spacings. The RCLK (Pin 26) 
signal is provided by some drives but if not it may be 


derived externally by Phase lock loops, one shots, or 
counter techniques. In addition, a Read Gate Signal 
is provided as an output (Pin 25) which can be used 
to inform phase lock loops when to acquire syn- 
chronization. When reading from the media in FM. RG 
is made true when 2 bytes of zeroes are detected. 
The FD179X must find an address mark within the 
next 10 bytes; otherwise RG is reset and the search 
for 2 bytes of zeroes begins all over again. If an ad- 
dress mark is found within 10 bytes, RG remains true 
as long as the FD179X is deriving any useful informa- 
tion from the data stream. Similarly for MFM, RG is 
made active when 4 bytes of “00” or “FF” are de- 
tected. The FD179X must find an address mark 
within the next 16 bytes, otherwise RG is reset and 
search resumes. 


During read operations (WG = 0), the VFOE (Pin 33) 
is Sota for phase lock loop synchronization. 
VFOE will go active when: 

a) Both HLT and HLD are True 

b) Settling Time, if programmed, has expired 

c) The 179X is inspecting data off the disk 
If WE/VFOE is not used, leave open or tie to a 10K 
resistor to +5. 


DISK WRITE OPERATION 


When writing is to take place on the diskette the 
Write Gate (WG) output is activated, allowing current 
to flow into the Read/Write head. As a precaution to 
erroneous writing the first data byte must be loaded 
into the Data Register in response to a Data Request 
from the FD179X before the Write Gate signal can be 
activated. 


Writing is inhibited when the Write Protect input is a 
logic low, in which case any Write command is im- 
mediately terminated, an interrupt is generated and 
the Write Protect status bit is set. The Write Fault in- 
put, when activated, signifies a writing fault condition 
detected in disk drive electronics such as failure to 
detect write current flow when the Write Gate is acti- 
vated. On detection of this fault the FD179X termi- 
nates the current command, and sets the Write Fault 
bit (bit 5) in the Status Word. The Write Fault input 
should be made inactive when the Write Gate output 
becomes inactive. 


For write operations, the FD179X provides Write 
Gate (Pin 30) and Write Data (Pin 31) outputs. Write 
data consists of a series of 500 ns pulses in FM 
(DDEN = 1) and 250 ns pulses in MFM (DDEN = 0). 
Write Data provides the unique address marks in 
both formats. 


Also during write, two additional signals are provided 
for write precompensation. These are EARLY (Pin 
17) and LATE (Pin 18). EARLY is active true when 
the WD pulse appearing on (Pin 30) is to be written 
early. LATE is active true when the WD pulse is to be 
written LATE. If both EARLY and LATE are low when 
the WD pulse is present, the WD pulse is to be written at 
nominal. Since write precompensation values vary from 
disk manufacturer to disk manufacturer, the actual 
value is determined by several one shots or delay lines 
which are located external to the FD179X. The write 
precompensation signals EARLY and LATE are valid 
for the duration of WD in both FM and MFM formats. 
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Whenever a Read or Write command (Type It or II!) 
is received the FD179X samples the Ready input. if 
this input is logic low the command is not executed 
and an interrupt is generated. All Type | commands 
are performed regardless of the state of the Ready 
input. Also, whenever a Type #1 or {Il command is re- 
ceived, the TG43 signal output is updated. 


COMMAND DESCRIPTION 


The FD179X will accept eleven commands. Com- 
mand words should only be loaded in the Command 
Register when the Busy status bit is off (Status bit 0). 
The one exception is the Force Interrrupt command. 
Whenever a command is being executed, the Busy 
status bit is set. When a command is completed, an 
interrupt is generated and the Busy status bit is re- 
set. The Status Register indicates whether the com- 
pleted command encountered an error or was fault 
free. For ease of discussion, commands are divided 
into four types. Commands and types are sum- 
marized in Table 2. 


Table 2 COMMAND SUMMARY 


Restore 

Seek 

Step 

Step In 

Step Out 

Read Sector 

Write Sector 

Read Address 

Read Track 

Write Track 

Force Interrrupt 
Note: Bits shown in TRUE form. 


6 
0 
0 
0 
1 
1 
0 
0 
1 
1 
1 
1 
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Table 3 FLAG SUMMARY 


TYPE | COMMANDS 


h_= Head Load Flag (Bit 3) 


h = 1, Load head at beginning 
h = 0, Unload head at beginning 


V_= Verify flag (Bit 2 


V = 1, Verify on destination track 
V = 0, No verify 


rifo = Stepping motor rate (Bits 1-0) 


Refer to Table 1 for rate summary 
u = Update flag (Bit 4) 


u = 1, Update Track register 
u = 0, No update 


Table 4 FLAG SUMMARY 


TYPE Il & tlt COMMANDS 


m = Multiple Record flag (Bit 4) 
m = 0, Single Record 
m = 1, Multiple Records 


@ = Data Address Mark (Bit 0) 


@ = 0, FB (Data Mark) 
a = 1, F8 (Deleted Data Mark) 


E = 15 ms Delay (2MHz) 
E = 1, 15 ms delay 
E = 0, no 15 ms delay 


(F,) S = Side Select Flag (1791/3 only) 


S = 0, Compare for Side 0 
S = 1,Compare for Side 1 


(F;) C = Side Compare Flag (1791/3 only) 
C = 0, disable side select compare 
C = 1, enable side select compare 
(F,) S = Side Select Flag 
(Bit 1, 1795/7 only) 
S = 0 Update SSO to 0 
S = 1 Update SSO to 1 


(F,) b = Sector Length Fla 
(Bit 3, 1975/7 only) 


Sector Length Field 


Table 5 FLAG SUMMARY 
TYPE IV COMMAND 


li = Interrupt Condition flags (Bits 3-0) 
10 = 1, Not-Ready to Ready Transition 


11 = 1, Ready to Not-Ready Transition 
12 = 1, Index Pulse 
13 = 1, Immediate Interrupt 


I3 -lg = 0, Terminate with no Interrupt 


TYPE | COMMANDS 


The Type | Commands include the Restore, Seek, 
Step, Step-in, and Step-Out commands. Each of the 
Type | Commands contains a rate field (rors), which 


determines the stepping motor rate as defined in 
Table 1. 
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The Type | Commands contain a head load flag (h) 
which determines if the head is to be loaded at the 
beginning of the command. If h = 1, the head is 
loaded at the beginning of the command (HLD output 
is made active). If h =0, HLD is deactivated. Once 
the head is loaded, the head will remain engaged 
until the FD179X receives a command that specifi- 
cally disengages the head. If the FD179X is idle 
(busy = 0) for 15 revolutions of the disk, the head will 
be automatically disengaged (HLD made inactive). 


The Type | Commands also contain a verification (V) 
flag which determines if a verification operation is to 
take place on the destination track. If V = 1, a verifi- 
cation is performed, if V = 0, no verification is per- 
formed. 


During verification, the head is loaded and after an 
internal 15 ms delay, the HLT input is sampled. 


When HLT is active (logic true), the first encountered 
1D field is read off the disk. The track address of the 


HA 


YP 
COMMAND BEEN 
RECEIVED 
> 


YES 


SET BUSY RESET CRC 
SEEK ERROR ORG INTAQ 


RESET HO 


E 
DIRECTION 


TYPE | COMMAND FLOW 


ID field is then compared to the Track Register; if 
there is a match and a valid ID CRC, the verification 
is complete, an interrupt is generated and the Busy 
status bit is reset. If there is not a match but there is 
valid ID CRC, an interrupt is generated, and Seek 
Error Status bit (Status bit 4) is set and the Busy 
status bit is reset. if there is a match but not a valid 
CRC, the CRC error status bit is set (Status bit 3), 
and the next encountered ID field is read from the 
disk for the verification operation. If an ID field with a 
valid CRC cannot be found after four revolutions of 
the disk, the FD179X terminates the operation and 
sends an interrupt, (INTRQ). 


The Step, Step-In, and Step-Out commands contain 
an Update flag (U). When U = 1, the track register is 
updated by one for each step. When U = 0, the track 
register is not updated. 


On the 1795/7 devices, the SSO output is not affected 
during Type 1 commands, and an internal side com- 
pare does not take place when the (V) Verify Flag is 


on. 
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70 


’ 
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RESTORE (SEEK TRACK 0) 


Upon receipt of this command the Track 00 (TROO) 
input is sampled. !f TROO is active low indicating the 
Read-Write head is positioned over track 0, the Track 
Register is loaded with zeroes and an interrupt is 
generated. if TROO is not active low, stepping pulses 
(pins 15 to 16) at a rate specified by the miro field are 
issued until the TROO input is activated. At this time the 
Track Register is loaded with zeroes and an interrupt is 
generated. {f the TROO input does not go active low 
after 255 stepping pulses, the FD179X terminates op- 
eration, interrupts, and sets the Seek error status bit. 
A verification operation takes place if the V flag is 
set. The h bit allows the head to be loaded at the 
start of command. Note that the Restore command is 
executed when MR goes from an active to an inac- 
tive state. 


INTAG RESET BUSY 


INTRO RESET BUSY 
SET SEEK EAROR 


INTRO 
RESET BUSY “ 


NOTE IF TEST 0 THERE 1S NO 15MS DELAY 
WTEST ‘AND CLK 1} Mee THERE IS A OMS DELAY 


TYPE ! COMMAND FLOW 


SEEK 


This command assumes that the Track Register con- 
tains the track number of the current position of the 
Read-Write head and the Data Register contains the 
desired track number. The FD179X will update the 
Track register and issue stepping pulses in the ap- 
propriate direction until the contents of the Track re- 


' gister are equal to the contents of the Data Register 
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(the desired track location). A verification operation 
takes place if the V flag is on. The h bit allows the 
head to be loaded at the start of the command. An 
interrupt is generated at the completion of the com- 
mand. 


STEP 


Upon receipt of this command, the FD179X issues 
one stepping pulse to the disk drive. The stepping 
motor direction is the same as in the previous step 
command. After a delay determined by theriro field, a 
verification takes place if the V flag is on. If the u flag is 
on, the Track Register is updated. The h bit allows the 
head to be loaded at the start of the command. An 
interrupt is generated at the completion of the command. 


STEP-IN 


Upon receipt of this command, the FD179X issues 
one stepping pulse in the direction towards track 76. 
If the u flag is on, the Track Register is incremented 
by one. After a delay determined by the rrto field, a 
verification takes place if the V flag is on. The h bit 
allows the head to be loaded at the start of the 
command. An interrupt is generated at the comple- 
tion of the command. 


STEP-OUT 


Upon receipt of this command, the FD179X issues 
one stepping pulse in the direction towards track 0. If 
the u flag is on, the Track Register is decremented by 
one. After a delay determined by the rro field, a ver- 
ification takes place if the V flag is on. The h bit al- 
lows the head to be loaded at the start of the com- 
mand. An interrupt is generated at the completion of 
the command. 


TYPE t| COMMANDS 


The Type Il Commands are the Read Sector and 
Write Sector commands. Prior to loading the Type II 
Command into the Command Register, the computer 
must load the Sector Register with the desired sector 
number. Upon receipt of the Type II command, the 
busy status Bit is set. If the E flag = 1 (this is the 
normal case) HLD is made active and HLT is sam- 
pled after a 15 msec delay. If the E flag is 0, the 
head is loaded and HLT sampled with no 15 msec 
delay. The !D field and Data Field format are shown 
on page 13. 


When an ID field is located on the disk, the FD179X 
compares the Track Number on the ID field with the 
Track Register. If there is not a match, the next en- 


countered !D field is read and a comparison is again 
made. If there was a match, the Sector Number of 
the ID field is compared with the Sector Register. If 
there is not a Sector match, the next encountered ID 
field is read off the disk and comparisons again 
made. If the ID field CRC is correct, the data field is 
then located and will be either written into, or read 
from depending upon the command. The FD179X 
must find an ID field with a Track number, Sector 
number, side number, and CRC within four revolutions 
of the disk; otherwise, the Record not found status bit is 
set (Status bit 3) and the command is terminated with an 
interrupt. 


is 
TYPE 
COMMANO 
RECEIVED 
> 
YES 


SET BUSY, RESET DRQ. LOST 
DATA, RECORD NOT FOUNO. & 
STATUS BITS 5 & 6 INTRO 


INTRO 
RESET BUSY 


COPY S FLAG TO 
‘SSO LINE (17957 ONLY) 


‘ 


INTAQ. RESET BUSY 
SET WRITE PROTECT 


FNOTE 1 TEST 0 THERE IS NO I5MS DELAY 
TEST bt AND CLK TMZ THERE IS TOMS DELAY 


TYPE ti COMMAND 
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Sector Length Table 


Number of Bytes 
in Sector (decimal!) 


Sector Length 
Field (hex) 


Each of the Type Il Commands contains an (m) flag 
which determines if multiple records (sectors) are to 
be read or written, depending upon the command. If 
m = 0, a single sector is read or written and an inter- 
rupt is generated at the completion of the command. 
lf m =1, multiple records are read or written with the 
sector register internally updated so that an address 
verification can occur on the next record. The 
FD179X will continue to read or write multiple records 
and update the sector register until the sector regis- 


odoES 
TA * TRACK 


ADORESS OF 10 
FIELO 
cy 
ooES 
SA = SECTOR 
ADORESS OF iD 
FieLo 
? 


TYPE i] COMMAND 


Ss 
E 
ee 
T 
i. 
ie) 
N 
2. 


ter exceeds the number of sectors on the track or 
until the Force Interrupt command is loaded into the 
Command Register, which terminates the command 
and generates an interrupt. 


If the Sector Register exceeds the number of sectors 
on the track, the Record-Not-Found status bit will be 
set. 


. The Type I! commands also contain side select com- 


pare flags. When C = 0, no side comparison is made. 
When C = 1, the LSB of the side number is read off the 
ID Field of the disk and compared with the contents of 
the (S) flag. If the S flag compares with the side number 
recorded in the ID field, the 179X continues with the 
ID search. If a comparison is not made within 5 index 
pulses, the interrupt line is made active and the Record- 
Not-Found status bit is set. 


The 1795/7 READ SECTOR and WRITE SECTOR com- 
mands include a ‘b’ flag. The ‘b’ flag, in conjunction with 
the sector length byte of the ID Field, allows different 
byte lengths to be implemented in each sector. For IBM 
compatability, the ‘b’ flag should be set to a one. The 


HAS 
DATA AM 
OCCURED 

IN TIME 
> 


WAS 
NEXT BYTE 
BEEN ASSEMBLED 
IN OSR 
a 
€S 


S| 
¥' 
Ss 


READ BY i 


3 
COMPUTER 
ORO 0 
? 


INTRO. RESET BUSY 
SET CAC ERROR 


TYPE Ii COMMAND 


INTAQ RESET BUSY 


‘s' flag allows direct contro! over the SSO Line (Pin 25) 
and is set or reset at the beginning of the command, 
dependent upon the value of this flag. 


READ SECTOR 


Upon receipt of the Read Sector command, the head 
is loaded, the Busy status bit set, and when an ID 
field is encountered that has the correct track 
number, correct sector number, correct side number, 
and correct CRC, the data field is presented to the 
computer. The Data Address Mark of the data field must 
be found within 30 bytes in single density and 43 bytes in 
double density of the last ID field CRC byte; if not, the 
Record Not Found status bit is set and the operation is 
terminated. 


When the first character or byte of the data field has 
been shifted through the DSR, it is transferred to the 
DR, and DRQ is generated. When the next byte is 
accumulated in the OSR, it is transferred to the OR 
and another DRQ is generated. If the Computer has 
not read the previous contents of the DR before a 
new character is transferred that character is lost and 


DELAY 2 BYTES OF GaP 


OELAY @ BYTES OF GAP 


bated INTRO, RESET BUSY 
SETLOST DATA 


ves 


> 
YES 
DELAY 1 BYTE OF GaP 


TURN ON WG & WAITE 


€ BYTES OF ZEROS DELAY 11 BYTES 


WRITE DATA AM 
ACCOROING TO AO FIELD 
OF WRITE COMMAND 


TURN ON WG & WRITE 
12 BYTES OF ZEROS 


OA TO OSA SET ORO 


WRITE BYTE TO DISK 


WRITE 1 BYTE OF FF 


TYPE I! COMMAND 
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the Lost Data Status bit is set. This sequence con- 
tinues until the complete data field has been inputted 
to the computer. If there is a CRC error at the end of 
the data field, the CRC error status bit is set, and the 
command is terminated (even if it is a multiple record 
command). 


At the end of the Read operation, the type of Data 
Address Mark encountered in the data field is re- 
corded in the Status Register (Bit 5) as shown below: 


STATUS 
BIT 5 
1 Deleted Data Mark 
0 Data Mark 
WRITE SECTOR 


Upon receipt of the Write Sector command, the head 
is loaded (HLD active) and the Busy status bit is set. 
When an ID field is encountered that has the correct 
track number, correct sector number, correct side num- 
ber, and correct CRC, a DRQ is generated. Ths FD 17", ¢ 
counts off 11 bytes in single density and 22 bytes in 
double density from the CRC field and the Write Gate 
(WG) output is made active if the DRQ is serviced (i.e., 
the DR has been loaded by the computer). If DRQ has 
not been serviced, the command is terminated and the 
Lost Data status bit is set. If the DRO has been ser- 
viced, the WG is made active and six bytes of zeros 
in single density and 12 bytes in double density are 
then written on the disk. At tnis time the Data Ad- 
dress Mark is then written on the disk as determined 
by the ao field of the command as shown below: 


ao Data Address Mark (Bit 0) 
1 Deleted Data Mark 
0 Data Mark 


The FD179X then writes the data field and generates 
DRQ's to the computer. If the DRQ is not serviced in 
time for continuous writing the Lost Data Status Bit is 
set and a byte of zeros is written on the disk. The 
command is not terminated. After the last data byte 
has been written on the disk, the two-byte CRC is 
computed internally and written on the disk followed 
by one byte of logic ones in FM or in MFM. The WG 
output is then deactivated. 


TYPE ill COMMANDS 
READ ADDRESS 


Upon receipt of the Read Address command, the 
head is loaded and the Busy Status Bit is set. The 


next encountered ID field is then read in from the 
disk, and the six data bytes of the ID field are as- 
sembled and transferred to the DR, and a DRQ is 
generated for each byte. The six bytes of the ID field 
are shown below: 


TRACK | SIDE SECTOR ie lee 
ADDR | NUMBER | ADDRESS | LENGTH | 1 
pa jf 2 | ss fs Ts fel 


Although the CRC characters are transferred to the 
computer, the FD179X checks for validity and the 
CRC error status bit is set if there is a CRC error. 
The Track Address of the ID field is written into the 
sector register. At the end of the operation an inter- 
rupt is generated and the Busy Status is reset. 


READ TRACK 


Upon receipt of the Read Track command, the head 
is loaded and the Busy Status bit is set. Reading 
starts with the leading edge of the first encountered 
index pulse and continues until the next index pulse. 
As each byte is assembled it is transferred to the 
Data Register and the Data Request is generated for 
each byte. No CRC checking is performed. Gaps are 
included in the input data stream. The accumulation 
of bytes is synchronized to each Address Mark en- 
countered. Upon completion of the command, the in- 
terrupt is activated. RG is not activated during the 
Read Track Command. An internal side compare is not 
performed during a Read Track. 


WRITE TRACK 


Upon receipt of the Write Track command, the head 
is loaded and the Busy Status bit is set. Writing 
starts with the leading edge of the first encountered 
index pulse and continues until the next index pulse, 
at which time the interrupt is activated. The Data Re- 
quest is activated immediately upon receiving the 
command, but writing will not start until after the first 
byte has been loaded into the Data Register. If the 
DR has not been loaded by the time the index pulse 
is encountered the operation is terminated making 
the device Not Busy, the Lost Data Status Bit is set, 
and the Interrupt is activated. If a byte is not present 
in the DR when needed, a byte of zeros is substi- 
tuted. Address Marks and CRC characters are writ- 
ten on the disk by detecting certain data byte pat- 
terns in the outgoing data stream as shown in the 


table below. The CRC generator is initialized when... 
any data byte from F8 to FE is about to be transfer- ..* 


red from the DR to the OSR in FM or by receipt of 
F5 in MFM. 


TRACK | SIDE |SECTOR/ SECTOR /|CRC|CRC}GAP | DATA CRC | CRC 
NUMBER |NUMBER|NUMBER|LENGTH} 1 2 iI AM ;DATAFIELD| 1 2 


ID FIELD DATA FIELD 


In MFM only, IDAM and DATA AM are preceded by three bytes of A1 with clock transition between bits 4 and § 


missing. 
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NO (FM) 


DOES WRITE 2 CAC 
DSA: ‘r CHARS CLK FF 


INTRO 
RESET BUSY 


WRITE FC 
Cun OF 


WRITE FO FE OR 
FO-FB CLK C? 
INITIALIZE CAC 


vFS 


vES 
COPY S$ FLAG TO 
SSO CINE 11795 7 ONLY: 


WRITE OSA 
C.K FF 


Ss 
E 
Cc 
Tee 
! 
ce) 
N 
2 


YE PHYS 
INTRQ RESET BUSY (NDE X MARK 
. 


mas HAS 
IS MS INOEX 
ExPIREO PULSE 
* OCCURED 
YES 


WAITE Al" IN MEM 
wiTH MISSING CLOCK 
INITIALIZE CAC 


WRITE C2" IN MFM 
WITH MISSING CLOCK 
WRITE 2 CAC 
CHARS 


SET INTAQ HAS 
LOST DATA ORO BEEN 
RESET BUSY SEAVICE 


TYPE Ill COMMAND WRITE TRACK 


TYPE Il] COMMAND WRITE TRACK 


CONTROL BYTES FOR INITIALIZATION 
DATA PATTERN FD179X INTERPRETATION FD1791/3 INTERPRETATION 
IN DR (HEX) IN FM (DDEN = 1) IN MFM (ODEN = 0) 


00 thru F4 Write 00 thru F4 with CLK = FF Write 00 thru F4, in MFM 

F5 Not Allowed Write A1* in MFM, Preset CRC 
F6 Not Allowed Write C2** in MFM 

F7 Generate 2 CRC bytes Generate 2 CRC bytes 

F8 thru FB Write F8 thru FB, Clk = C7, Preset CRC Write F8 thru FB, in MFM 

F Write FC with Clk = D7 Write FC in MFM 


Write FD in MFM 
Write FE in MFM 
Write FF in MFM 


Write FD with Clk = FF 
Write FE, Clk = C7, Preset CRC 
Write FF with Clk = FF 


*Missing clock transition-between bits 4 and 5 **Missing clock transition between bits 3 & 4 
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SET BUSY 
RESET STATUS 
BITS 2, 4,5 


COPY'S FLAG 
TO SSO LINE 
(1798/7 ONLY) 


a) 
“ € 
Cc 
T 
I 
Oo 
N 
wa 2 


SET INTRQ 
RESET BUSY 


HAVE 8 
BITS BEEN 


ASSEMBLED 
DELAY 15MS* ? 


“tt TEST= @, NO DELAY TYPE iil COMMAND 
WTEST=1 and CLK=1 MHZ, 30 MS DELAY Read Track/Address 
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TYPE iV COMMAND 


FORCE INTERRUPT 


This command can be loaded into the command re- 
gister at any time. If there is a current command 
under execution (Busy Status Bit set), the command 
will be terminated and an interrupt will be generated 
when the condition specified in-the lo through Is field 
is detected. The interrupt conditions are shown be- 
low: 


RESET BUSY 


lo = Not-Ready-To-Ready Transition 

11 = Ready-To-Not-Ready Transition 

l2 = Every Index Pulse 

ls = Immediate Interrupt (requires reset, see 


DAM BEE Hote) 
DETECTED NOTE: Iflo — Is = 0, there is no interrupt generated but 
?. 


the current command is terminated and busy is 
reset. This is the only command that will enable 
the immediate interrupt to clear on a subse- 
quent Load Command Register or Read Status 


fiegister. 
STATUS DESCRIPTION 
Upon receipt of any command, except the Force In- 


terrupt command, the Busy Status bit is set and the 
rest of the status bits are updated or cleared for the 


new command. If the Force Interrupt Command is 
avte ron received when there is a current command under 
execution, the Busy status bit is reset, and the rest of 


the status bits are unchanged. If the Force Interrupt 
command is received when there is not a current 
command under execution, the Busy Status bit is 
reset and the rest of the status bits are updated or 
cleared. In this case, Status reflects the Type | com- 
: mands. 


S 
E 
Cc 
pe 
I. 
O° 
2) 


SET ORQ 


‘evTeS BEEN The format of the Status Register is shown below: 
REAO : 
? 


TRANSFER TRACK 
NUMBER TO SECTOR 
REGISTOR 


Status varies according to the type of command exe- 


CAC YES cuted as shown in Table 6. 
ERROR 
? 


SET INTRO 
RESET BUSY 


TYPE Ilt COMMAND 
Read Track/Address 
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FORMATTING THE DISK 


(Refer to section on Type I!t commands for flow diag- 
rams.) 


Formatting the disk is a relatively simple task when 
operating programmed I/O or when operating under 
Formatting the disk is accomplished by positioning 
the R/W head over the desired track number and is- 
suing the Write Track command. Upon receipt of the 
Write Track command, the FD179X raises the Data 
Request signal. At this point in time, the user loads 
the data register with desired data to be written on 
the disk. For every byte of information to be written 
on the disk, a data request is generated. This sequ- 
ence continues from one index mark to the next 
index mark. Normally, whatever data pattern appears 
in the data register is written on the disk with a nor- 
mal clock pattern. However, if the FD179X detects a 
data pattern of F5 thru FE in the data register, this is 
interpreted as data address marks with missing 
clocks or CRC generation. For instance, in FM an FE 
pattern will be interpreted as an ID address mark 
(DATA-FE, CLK-C7) and the CRC will be initialized. 
An F7 pattern will generate two CRC characters in 
FM or MFM. As a consequence, the patterns F5 thru 
FE must not appear in the gaps, data fields, or ID 
fields. Also, CRC’s must be generated by an F7 pat- 
tern. 

Disks may be formatted in IBM 3740 or System 34 
formats with sector lengths of 128, 256, 512, or 1024 
bytes. 


aanoy 
TRANSITION 


“MISSING CLOCK 1M 
BE'WEEN @ITS BAN 4 


tw 
wie 22 OVTES. 


WATE GATE TURN ON FOR UPDATE 
OF NENT DATA HIELO 


IBM 3740 FORMAT—128 BYTES/SECTOR 


Shown below is the IBM single-density format with 
128 bytes/sector. In order to format a diskette, the 
user must issue the Write Track command, and load 
the data register with the following values. For even 
byte to be written, there is one data request. 


NUMBER HEX VALUE OF 
OF BYTES BYTE WRITTEN 
40 FF (or 00)! 
6 00 
1, FC (Index Mark) 
» 2. FF (or 00) 
6 00 
1 FE (ID Address Mark) 
1 Track Number 
1 Side Number (00 or 01) 
1 Sector Number (1 thru 1A) 
1 00 
1 F7 (2 CRC’'s written) 
1 FF (or 00) 
6 00 
Tr FB (Data Address Mark) 


Data (IBM uses £5) 
F7 (2 CRC’s written) 
FF (or 90) 
247** FF (or 00) 


“Write bracketed field 26 times 


**Continue writing until FD179X interrupts out. 
Approx. 247 bytes. 
1-Optional ‘00’ on 1795/7 only. 


WATE TURN OFF FOR UPDATE 
Of PREVIOUS DATA FELD 
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IBM SYSTEM 34 FORMAT- 
256 BYTES/SECTOR 


Shown below is the IBM dual-density format with 256 
bytes/sector. In order to format a diskette the user 
must issue the Write Track command and load the 
data register with the following values. For every byte 
to be written, there is one data request. 


NUMBER 
OF BYTES 


HEX VALUE OF 
BYTE WRITTEN 


4E 
00 
F6 


1. NON-IBM FORMATS 


Variations in the IBM format are possible to a limited 
extent if the following requirements are met: sector 
size must be a choice of 128, 256, 512, or 1024 bytes; 
gap size must be according to the following table. Note 
that the Index Mark is not required by the 179X. The 
minimum gap sizes shown are that which is required by 
the 179X, with PLL lock-up time, motor speed variation, 
etc., adding additional bytes. 


FC (Index Mark) 
4E 


FE (ID Address Mark) 
Track Number (0 thru 4C) 
Side Number (0 or 1) 
Sector Number (1 thru 1A) 
01 


16 bytes FF 


11 bytes FF 


6 bytes 00 


10 bytes FF 


32 bytes 4E 


22 bytes 4E 


12 bytes 00 
3 bytes Al 


24 bytes 4E 


F7 (2 CRCs written) 
4E 3 bytes A1 
00 

F5 

FB (Data Address Mark) 
DATA 

F7 (2 CRCs written) 

4E 

4E 


4 bytes 00 8 bytes 00 


16 bytes FF 


16 bytes 4E 


* Write bracketed field 26 times 
**Continue writing until FD179X interrupts out. 
Approx. 598 bytes. 


*Byte counts must be exact. 
**Byte counts are minimum, except exactly 3 bytes 
of A1 must be written. 


ELECTRICAL CHARACTERISTICS 
MAXIMUM RATINGS 
Voo With Respect to Vss (Ground) =15 to —0.3V 


Max. Voltage to Any Input With =15 to —0.3V 
Respect to Vss : 


Vpp = !D ma Nominal 


0°C to 70°C 
—55°C to +125°C 


Operating Temperature 
Storage Temperature 


Voc = 35 ma Nominal 


OPERATING CHARACTERISTICS (DC) 


TA = 0°C to 70°C, Voo = + 12V + .6V, Vss = OV, Vec = + 5V + .25V 


SnOL CHARACTERISTIC. | MIN. | MAX. | UNITS | CONDITIONS 


Input Leakage : 10 
Output Leakage 
Input High Voltage 
Input Low Voltage 
Output High Voltage 
Output Low Voltage 
Power Dissipation 


348 


TIMING CHARACTERISTICS 
Ta = 0°C to 70°C, Voo = + 12V + .6V, Vss = OV, Vec = +5V + .25V 


READ ENABLE TIMING 


SYMBOL CHARACTERISTIC Min. | Typ. | MAX. | UNITS | CONDITIONS 


Setup ADDR & CS to RE_| 
Hold ADDR & CS from RE 
RE Pulse Width 

DRQ Reset from RE_ 
INTRQ Reset from RE 
Data Access from RE 
Data Hold From RE 


Ci. = 50 pf 


See Note 5 
Ci = 50 pf 
C. = 50 pf 


S 
E 
Cc 
T 
t 
0 
N° 
2 


MOTE + TE MAY BE PERMANENTLY TIED LOW IF DESIMED 
“TIME DOUBLES WHEN CLOCK Shiny 


t SERVICE tWORST CASE! 
‘FM (27SuS 


“MEM = 135uS 


READ ENABLE TIMING 
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WRITE ENABLE TIMING 


[_snisot | GRNcrERITG [wn [ WER [ ONS | conorions— 


Setup ADDR & CS to WE 
Hold ADDR & CS from WE 
WE Pulse Width ___ 

DRQ Reset from WE 
INTRQ Reset from WE 
Data Setup to WE 
Data Hold from WE 


See Note 5 


INPUT DATA TIMING: 


CHARACTERISTIC a UNITS | CONDITIONS 


Raw Read Pulse Width See Note 1 
Raw Read Cycle Time 1800 ns @ 70°C 


RCLK Cycle Time 1800 ns @ 70°C 
RCLK hold to Raw Read See Note 1 
Raw Read hold to RCLK 


Faw READ 


1 SERVICE «WORST CASE) 


RE 
CIN FM, 14 wSEC 


0 THE 
Hd Sala pe ten These MES ARE Boteceo WHEN Cok 1 Mar INPUT DATA TIMING 


WRITE ENABLE TIMING 
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WRITE DATA TIMING: (ALL TIMES DOUBLE WHEN CLK = 1 MHz) 


SYMBOL CHARACTERISTICS | MIN. | TYP. | MAX. | UNITS] CONDITIONS 


Write Data Pulse Width FM 
MFM 


Write Gate to Write Data FM 

MFM 
Write data cycle Time +CLK Error 
Early (Late) to Write Data MFM 
Early (Late) From MFM 
Write Data 


Write Gate off from WD FM 
MFM 


WD Valid to Cik CLK=1 MHZ 
CLK=2 MHZ 


WD Valid after CLK CLK=1 MHZ 
CLK=2 MHZ 


WRITE DATA/CLOCK RELATIONSHIP 
(ODEN= 0) 


WRITE DATA TIMING 
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MISCELLANEOUS TIMING: 


| sympou | cHaRacrTeristic | MIN. | Typ. | max. | UNITS | CONDITIONS | 


Clock Duty (low) 
Clock Duty (high) 
Step Pulse Output See Note 5 


Dir Setup to Step 
Master Reset Pulse Width + CLK ERROR 


Index Pulse Width 


Write Fault Pulse Width See Note 5 


J 
beer 


-adtco 


wae) 


STEP IN 
von 
vou 
| so0 af'ste|=_—fsree fe toe o|'s0° [= 


aici Mes ey 


MISCELLANEOUS TIMING 


NOTES: 

1. Pulse width on RAW READ (Pin 27) is normally 3. tbc should be 2 ys, nominal in MFM and 4 xs nominal 
100-300 ns. However, pulse may be any width if in FM. Times double when CLK = 1 MHz. 
pulse is entirely within window. If pulse occurs in both 4. RCLK may be high or low during RAW READ (Polarity 
windows, then pulse width must be less than 300 ns is unimportant). 


for MFM at CLK = 2 MHz and 600 ns for FM at 2 5. Times double when clock = 1 MHz. 
MHz. Times double for 1 MHz. 
2. APPL Data Separator is recommended for 8” MFM.- 
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3 “FDI79X Application Notes a 


INTRODUCTION 


Over the past several years, the Floppy Disk Drive has 
become the most popular on-line storage device for 
mini and microcomputer systems. Its fast access time, 
, reliability and low cost-per-bit ratio enables the Floppy 
: Disk Drive to be the solution in mass storage for mi- 
' croprocessor systems. The drive interface to the Host 

system is standardized, allowing the OEM to substitute 

one drive for another with minimum hardware/ software 
- modifications. * 


Since Floppy Disk Data is stored and retrieved as a 
self-clocking serial data stream, some means of sep- 
arating the clock from the data and assembling this 
data in parallel form must be. accomplished. Data is 
stored on individual Tracks of the media, requiring con- 
trol of a stepper motor to move the Read/Write head 
to a predetermined Track. Byte sychronization must 
also be accomplished to insure that the parallel data 
is properly assembled. After all the design considera- 
tions are met, the final controller can consist of 40 or 
more TTL packages. 


To alleviate the burden of Floppy Disk Controller de- 
sign, Western Digital has developed a Family of LS! 
Floppy Disk controller devices. Through its own set of 
macro commands, the FD179X Controller Family will 
perform all the functions necessary to read and write 
data to the drive. Both the 8” standard and 5%” mini- 
floppy are supported with single or double density re- 
cording techniques. The FD179X is compatible with 
the IBM 3740 (FM) data format, or the System 34 
(MFM) standards. Provisions for non-standard formats 
and variable sector lengths have been included to pro- 
vide more storage capability per track. Requiring stan- 
dard +5, +12 power supplies the FD179X is available 
in a standard 40 pin dual-in-line package. 


The FD179X Family consists of 6 devices. The 
differences between these devices is summarized in 
Figure 1. The 1792 and 1794 are “single density only” 
devices, with the Double Density Enable pin (ODDEN) 


left open by the user. Both True and inverted Data bus © - 


devices are available. Since the~179X can only drive 
one TTL Load, ‘a true data bus system may use the 
1791 with external inverting buffers to arrive at a true 
bus scheme. The .4795:atta'T797 are identical to the 
1791 and 1793, except a side select output has been 
added that is controlled through the Command Register. 


Bo Aer. 7 


~ up into “bit cells.” 
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SYSTEM DESIGN 


The first consideration in Floppy Disk Design is to de- 
termine which type of drive to use. The choice ranges 
from single-density single sided mini-floppy to the 8” 
double-density double-sided drive. Figure 2 illustrates 
the various drive and data capacities associated with 
each type. Although the 8” double-density drive offers 
twice as much storage, a more complex data separator 
and the addition of Write Precompensation circuits are 
mandatory for reliable data transfers. Whether to go 
with 8” double-density or not is dependent upon PC 
board space and the additional circuitry needed to ac- 
curately recover data with extreme bit shifts. The byte 
transfer time defines the nominal time required to 
transfer one byte of data from the drive. if the CPU 
used cannot service a byte in this time, then a DMA 
scheme will probably be required. The 179X also needs 
a few microseconds for overhead, which is subtracted 
from the transfer time. Figure 3 shows the actual ser- 
vice times that the CPU must provide on a byte-by-byte 
basis. If these times are not met, bytes of data will be 
lost during a read or write operation. For each byte 
transferred, the 179X generates a DRQ (Data Re- 
quest) signal on Pin 38. A bit is provided in the status 
register which is also set upon receipt of a byte from 
the Disk. The user has the option of reading the status 
register through program control or using the DRQ Line 
with DMA or interrupt schemes. When the data register 
is read, both the status register DRQ bit and the DRQ 
Line are automatically reset. The next full byte will 
again set the DRQ and the process continues until the 
sector(s) are read. The Write operation works exactly..-. 
the same way, except a WRITE to the Data Register 
causes a reset of both ORQ's. 


RECORDING FORMATS 


The FD179X accepts data from the disk in a Fre- 
quency-Modulated (FM) or Modified-Frequency-Mod- 
ulated (MFM) Format. Shown in Figures 4A and 4B are 
both these Formats when writing a Hexidecimal byte 
of ‘D2’. In the FM mode, the 8 bits of data are broken 
Each bit cell begins with a clock 
pulse and the center of the bit cell defines the data. If 
the data bit = 0, no pulse is written; if the data = 1, 
a pulse is written in the center of the cell. For the 8” 
drive, each clock is written 4 microseconds apart. 
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In the MFM mode, clocks are decoded into the data 
stream. The byte is again broken up into bit cells, with 
the data bit written in the center of the bit cell if data 
= 1, Clocks are only written if both surrounding data 
bits are zero. Figure 4B shows that this occurs only 
once between Bit cell 4 and 5. Using this encoding 
scheme, pulses can occur 2, 3 or 4 microseconds 
apart. The bit cell time is now 2 microseconds; twice 
as much data can be recorded without increasing the 
Frequency rate due to this encoding scheme. 


The 179X was designed to be compatible with the IBM 
3740 (FM) and System 34 (MFM) Formats. Although 
most users do not have a need for data exchange with 
{BM mainframes, taking advantage of these well stud- 
ied formats will insure a high degree of system 
performance. The 179X will allow a change in gap 
fields and sector lengths to increase usable storage 
capacity, but variations away from these standards is 
not recommended. Both IBM standards are soft-sector 
format. Because of the wide variation in address marks, 
the 179X can only support soft-sectored media. Hard 
sectored diskettes have continued to lose popularity, 
mainly due to the unavailability of a standard and the 
limitation of sector lengths imposed by the physical 
sector holes in the diskette. 


PROCESSOR INTERFACE 


The Interface of the 179X to the CPU consists of an 
8-bit Bi-directional bus, read/write controls and optional 
interrupt lines. By selecting the device via the CHIP 
SELECT Line, each of the five internal registers can 
be accessed. 


Shown below are the registers and their addresses: 


PINS|PING|PIN5| PIN 4 PIN 2 
cs | A | A RE=8 - WES 
o 1 o | o 

| 


DATA REG 
H1-Z 


-O00 
«x~—-=-O 
x<x=-—"O = 


Each time a command is issued to the 179X, the Busy 
bit is set and the INTRQ (Interrupt Request) Line is 
reset. The user has the option of checking the busy bit 
or use the INTRQ Line to denote command comple- 
tion. The Busy bit will be reset whenever the 179X is 
idle and awaiting a new command. The INTRQ Line, 
once set, can only be reset by a READ of the status 
register or issuing a new command. The MR (Master 
Reset) Line does not affect INTRQ. 


The Ao, A,, Lines used for register selections can be 
configured at the CPU in a variety of ways. These lines 
may actually tie to CPU address lines, in which case 
the 179X will be memory-mapped and addressed like 
RAM. They may also be used under Program Control 
by tying to a port device such as the 8255, 6820, etc. 
As a diagnostic tool when checking out the CPU in- 
terface, the Track and Sector registers should respond 
like “RAM” when the 179X is idle (Busy = INTRQ = 
0). 

Because of internal synchronization cycles, certain 
time delays must be introduced when operating under 
Programmed I/O. The worst case delays are: 


OPERATION NEXT 
OPERATION 


MFM = 14us* 


FM = 28us. 
NO DELAY 


*NOTE: Times Double when CLK = 1MHz (5%” drive) 


Other CPU interface lines are CLK, MR and DDEN. 
The CLK line should be 2MHz (8” drive) or 1MHz (51%” 
drive) with a 50% duty cycle. Accuracy should be +1% 
(crystal source) since all internal timing, including step- 
ping rates, are based upon this clock. 


The MR or Master Reset Line should be strobed a 
minimum of 50 microseconds upon each power-on 
condition. This line clears and initializes all internal reg- 
isters and issues a restore command (Hex ‘03’) on the 
rising edge. A quicker Stepping tae can be written to 
the command register after a MR, in which case the 
remaining steps will occur at the faster programmed 
rate. The 179X will issue a maximum of 255 stepping 
pulses in an attempt to expect the TROO line to go 
active low. This line should be connected to the drive’s 
TROO sensor. 


The DDEN line causes selection of either single den- 
sity (ODDEN = 1) or double density operation. DDEN 
should not be switched during a read or write operation. 
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FLOPPY DISK INTERFACE 


The Floppy Disk Interface can be divided into three 
sections: Motor Control, Write Signals and Read Sig- 
nals. All of these lines are capable of driving one TTL 
load and not compatible for direct connection to the 
drive. Most drives require an open-collector TTL inter- 
face with high current drive capability. This must be 
done on all outputs from the 179X. Inputs to the 179X 
may be buffered or tied to the Drives outputs, providing 
the appropriate resistor termination networks are used. 
Undershoot should not exceed —0.3 volts, while integ- 
rity of Vis and Voy levels should be kept within spec. 


MOTOR CONTROL 


Motor Control is accomplished by the STEP and DIRC 
Lines. The STEP Line issues stepping pulses with a 
period defined by the rate field in all Type | commands. 
The DIRC Line defines the direction of steps (DIRC = 
1 STEP IN/DIRC = 0 STEP OUT). 


Other Control Lines include the IP or Index Pulse. This 
Line is tied to the drives’ Index L.E.D. sensor and 
makes an active transition for each revolution of the 
diskette. The TROO Line is another L.E.D. sensu: that 
informs the 179X that the stepper motor is at its fur- 
thest position, over Track 00. The READY Line can be 
used for a number of functions, such as sensing “door 
open”, Drive motor on, etc. Most drives provide a pro- 
grammable READY Signa! selected by option jumpers 
on the drive. The 179X will look at the ready signal prior 
to executing READ/WRITE commands. READY is not 
inspected during any Type | commands. All Type | 
commands will execute regardless of the Logic Level 
on this Line. 


WRITE SIGNALS 


Writing of data is accomplished by the use of the WD, 
WG, WF, TG43, EARLY and LATE Lines. The WG or 
Write Gate Line is used to enable write current at the 
drive’s R/W head. It is made active prior to writing data 
on the disk? The WF or WRITE FAULT Line is used to 
inform the 179X of a failure in drive electronics. This 
signal is multiplexed with the VFOE Line and must be 
logically separated if required. Figure 5 illustrates three 
methods of demultiplexing. 


The TG43 or “TFACK GREATER than 43” Line is 
used to decrease the Write current on the inner tracks, 
where bit densities are the highest. If not required on 
the drive, TG43 may be left open. 


WRITE PRECOMPENSATION 


The 179X provides three signals for double density 
Write Precompensation use. These signals are WRITE 
DATA, EARLY and LATE. When using single density 
drives (eighter 8” or 5%”), Write Precompensation is 
not necessary and the WRITE DATA line is generally 
TTL Buffered and sent directly to the drive. In this 
mode, EARLY and LATE are left open. 


For double density use, Write Precompensation is a 
function of the drive. Some manufacturers recommend 
Precompensating the 5%” drive, while others do not. 
With the 8” drive, Precompensation may be specified 
from TRACK 43 on, or in most cases, all TRACKS. If 
the recommended Precompensation is not specified, 
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check with the manufacturer for the proper configura- 
tion required. ‘ 


The amount of Precompensation time also varies. A 
typical value will usually be specified from 100-300ns. 
Regardless of the parameters used, Write Precom- 

ensation must be done external to the 179X. When 
DDEN is tied low, EARLY or LATE will be activated at 
least 125ns. before and after the Write Data pulse. An 
Algorithm internal the 179X decides whether to raise 
EARLY or LATE, depending upon the previous bit pat- 
tern sent. As an example, suppose the recommended 
Precomp value has been specified at 150ns. The fol- 
lowing action should be taken: 


EARLY LATE ACTION TAKEN 
0 0 delay WD by 150ns (nominal) 
0 1 delay WD by 300ns (2X value) 
1 0 do not delay WD 
There are two methods of performing Write 
Precompensation: 
1) External Delay elements 
2) Digitally 


Shown in Figure 6 is a Precomp circuit using the West- 
ern Digital 2143 clock generator as the delay element. 
The WD pulse from the 179X creates a strobe to the 
2143, causing subsequent output pulses on the.01, 22 
and 83 signals. The 5K Precomp adjust sets the de- 
sired Precomp value. Depending upon the condition of 
EARLY and LATE, £1 will be used for EARLY, £2 for 
nominal (EARLY = LATE = 0), and 83 for LATE. The 
use of “one-shots” or delay line in a Write Precom- 
pensation scheme offers the user the ability to vary the 
Precomp value. The 24 output resets the 74LS175 
Latch in anticipation of the next WD pulse. Figure 7 
shows the WD-EARLY/LATE relationship, while Figure 
8 shows the timing of this write Precomp scheme. 


Another method of Precomp is to perform the function 
digitally. Figure 9 illustrates a relationship between the 
WD pulse and the CLK pin, allowing a digital Precomp 
scheme. Figure 10 shows such a scheme with a pre- 
set Write Precompensation value of 250ns. The syn- 
chronous counter is used to generate 2MHz and 4MHz 
clock signals. The 2MHz clock is sent to the CLK input 
of the 179X and the 4MHz is used by the 4-bit shift 
register. When a WD pulse is not present, the 4MHz 
clock is shifting “ones” through the shift register and 
maintaining Qp at a zero level. When a WD pulse is 
present, a zero is loaded at either A, B, or C depending 
upon the states of LATE, EN PRECOMP and EARLY. 
The zero is then shifted by the 4MHz clock until it 
reaches the Q, output. The number of shift operations 
determines whether the WRITE DATA pulse is written 
early, nominal or late. if both FM and MFM operations 
is a system requirement, the output of this circuit should 
be disabled and the WD pulse should be sent directly 
to the drive. 
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DATA SEPARATION 


The 179X has two inputs (RAW READ & RCLK) and 
one output (VFOE) for use by an external data sepa- 
rator. The RAW READ input must present clock and 
data pulses to the 179X, while the RCLK input provides 
a “window” or strobe signal to clock each RAW READ 
pulse into the device. An ideal Data Separator would 
have the leading edge of the RAW READ pulse occur 
in the exact center of the RCLK strobe. 


Motor Speed Variation, Bit shifts and read amplifier 
recovery circuits all cause the RAW READ pulses to 
drift away from their nominal positions. As this occurs, 
the RAW READ pulses will shift left or right with re- 
spect to RCLK. Eventually, a pulse will make its tran- 
sition outside of its RCLK window, causing either a 
CRC error or a Record-not-Found error at the 179X. 


A Phase-Lock-Loop circuit is one method of achieving 
synchronization between the RCLK and RAW READ 
signals. AS RAW READ pulses are fed to the PLL, 
minor adjustments of the free-running RCLK frequency 
can be made. If pulses are occurring too far apart, the 
RCLK frequency is decreased to keep synchroniza- 
tion. If pulses begin to occur closer together, RCLK is 
increased until this new higher frequency is achieved. 
In normal read operations, RCLK will be constantly 
adjusted in an attempt to match the incoming RAW 
READ frequency. 


Another method of Data Separation is the Counter- 
Separator technique. The RCLK signal is again free- 
running at a nominal rate, until a RAW READ pulse 
occurs. The Separator then denotes the position of the 
pulse with respect to RCLK (by the counter value), and 
counts down to increase or decrease the current RCLK 
window. The next RCLK window will occur at a nominal 
rate and will continue to run at this frequency until an- 
other RAW READ pulse adjusts RCLK, but only the 
present window is adjusted. 


Both PPL and Counter/Separator are acceptable 
methods of Data Separation. The PPL has the highest 
reliability because of its “tracking” capability and is rec- 
ommended for 8” double density designs. 


As a final note, the term “Data Separator” may be 
misleading, since the physical separation of clock and 
data bits are not actually performed. This term is used 
throughout the industry, and can better be described 
as a “Data Recovery Circuit” rather than a Data 
Separator. 


The VFOE signal is an output from the 179X that sig- 
nifies the head has been loaded and valid data pulses 
are appearing on the RAW READ line. It can be used 
to enable the Data Separator and to insure clean RCLK 
transitions to the 179X. Since some drives will output 
random pulses when the head is disengaged, VFOE 
can prevent an erratic RCLK signal during this time. If 
the Data Separator requires synchronization during a 
known pattern of one’s or zero’s, then RG (READ 
GATE) can be used. The RG signal will go active when 
the 179X is currently over a field of zeros or ones. RG 
is not available on the 1795/1797 devices, since this 
signal was replaced with the SSO (Side Select Output) 
Line. 


Shown in Figure 11 is a 2¥%2 IC Counter/Separator. The 
74LS193 free runs at a frequency determined by the 
CRYCLK input. When a RAW READ pulse occurs, the 
counter is loaded with a starting count of ‘5’. When the 
RAW READ Line returns to a Logic 1, the counter 
counts down to zero and again free runs. The 74LS74 
insures a 50% duty cycle to the 179X and performs a 
divide-by-two of the Q, output. 


Figure 12 illustrates another Counter/Separator utiliz- 
ing a PROM as the count generator. Depending upon 
the RAW READ phase relationship to RCLK, the PROM 
is addressed and its data output is used as the counter 
value. A 16MHz clock is required for 8” double density, 
while an 8MHz clock can be used for single density. 


Figure 13 shows a Phase-Lock-Loop data recovery 
circuit. The phase detector (U2, Figure 2) compares 
the phase of the SHAPED DATA pulse to the phase 
of VFO CLK + 2. If VFO CLK.+ 2 is lagging the 
SHAPED DATA pulse an output pulse on #9, U2 is 
generated. The filter/amplifier converts this pulse into 
a DC signal which increases the frequency of the VCO. 
If, correspondingly, CLK + 2 is leading the SHAPED 
DATA pulse, an output pulse on #5, U2 is generated. 
This pulse is converted into a DC signal which de- 
creases the frequency of the VCO. These two actions 
cause the VCO to track the frequency of the incoming 
READ DATA pulses. This correction process to keep 
the two signals in phase is constantly occurring because 
of spindle speed variation and circuit parameter 
variations. 

The operating specifications for this circuit are as 
follows: 


2MHz 

+ 15% 

50 microsec. “1111” or 
“0000” Pattern 

100 Microsec “1010” Pat- 
tern 


Free Running Frequency 
Capture Range 
Lock Up Time 


The RAW READ pulses are generated from the falling 
edge of the SHAPED DATA pulses. The pulses are 
also reshaped to meet the 179X requirements. VFO 
CLK + 2 OR 4 is divided by 2 once again to obtain 
VFO CLK OUT whose frequency is that required by the 
179X RCLK input. RCLK must be controlled by VFOE 
so VFOE is sampled on each rising edge of VFO CLK 
OUT. When VFOE goes active EN RCLK goes active 
in synchronization with VFO CLK OUT preventing any 
glitches on the RCLK output. When VFOE goes inac- 
tive EN RCLK goes inactive in synchronization with 
VFO CLK OUT, again preventing any glitches on the 
RCLK output. 


Figure 14 illustrates a PPL data recovery circuit using 
the Western Digital 1691 Floppy Support device. Both 
data recovery and Write Precomp Logic is contained 
within the 1691, allowing low chip count and PLL re- 
liability. The 74S124 supplies the free-running VCO 
output. The PUMP UP and PUMP DOWN signals from 
the 1691 are used to control the 74S124’s frequency. 
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COMMAND USAGE 


Whenever a command is successfully or unsuccess- 
fully completed, the busy bit of the status register is 
reset and the INTRQ line is forced high. Command ter- 
mination may be detected either way. The INTRQ can 
be tied to the host processor's interrupt with an appro- 
priate service routine to terminate commands. The 
busy bit may be monitored with a user program and 
will achieve the same results through software. Per- 
forming both an INTRQ and a busy bit check is not 
recommended because a read of the status register to 
determine the condition of the busy bit will reset the 
INTRQ line. This can cause an INTRQ from not 
occurring. 


RESTORE COMMAND 


On some disk drives, it is possible to position the R/W 
head outward past Track 00 and prevent the TROO 
line from going low unless a STEP IN is first performed. 
If this condition exists in the drive used, the RESTORE 
command will never detect a TROO. Issuing several 
STEP IN pulses before a RESTORE command will 
remedy this situation. The RESTORE and all other 
Type | commands will execute even though the READY 
bit indicates the drive is not ready (NOT READY = 1). 


READ TRACK COMMAND 


The READ TRACK command can be used to manually 
inspect data on a hard copy printout. Gaps, address 
marks and all data are brought in to the data register 
during this command. The READ TRACK command 
may be used to inspect diskettes for valid formatting 
and data fields as well as address marks. Since the 
179X does not synchronize clock and data until the In- 
dex Address Mark is detected, data previous to this ID 
mark will not be valid. READ GATE (RG) is not ac- 
tuated during this command. 


READ ADDRESS COMMAND 


In systems that use either multiple drives or sides, the 
read address command can be used to tell the host 
processor which drive or side is selected. The current 
position of the R/W head is also denoted in the six 
bytes of data that are sent to the computer. 


CRS CRC | CRC 
TRACK SIDE } SECTOR LENGTH 


The READ ADDRESS command as well as all other 
Type I! and Type II! commands will not execute if the 
READY line is inactive (READY = Q). Instead, an in- 
terrupt will be generated and the NOT READY status 
bit will be set to a 1. 
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FORCED INTERRUPT COMMAND 


The Forced Interrupt command is generally used to 
terminate a multiple sector command or to insure Type 
I status in the status register. The lower four bits of the 
command determine the conditional interrupt as follows: 


NOT-READY TO READY TRANSITION 
READY TO NOT-READY TRANSITION 
EVERY INDEX PULSE 

IMMEDIATE INTERRUPT 


Regardless of the conditional! interrupt set, any com- 
mand that is currently being executed when the Forced 
Interrupt command is loaded will immediately be ter- 
minated and the busy bit will be reset indicating an idle 
condition. 


Then, when the condition for interrupt is met, the INTRQ 
line will go high signifying that the condition specified 
has occurred. 

The conditional interrupt is enabled when the corre- 
sponding bit positions of the command (I, —1!,) are set 
toa 1. If 1; —|) are all set to zero, no interrupt will occur, 
but any command presently under execution will be 
immediately terminated upon receipt of the Force In- 
terrupt command (HEX DO). 


As usual, to clear the interrupt a read of the status reg- 
ister or a write to the command register is required. 
The exception is when using the immediate interrupt 
condition (I, = 1). If this command is loaded into the 
command register, an interrupt will be immediately 
generated and the current command terminated. 
Reading the status or writing to the command register 
will not automatically clear the interrupt; another forced 
interrupt command with |, —|, = 0 must be loaded into 
the command register in order to reset the INTRQ from 
this condition. 


More than one condition may be set at a time. If for 
example, the READY TO NOT-READY condition (1, = 
1) and the Every Index Pulse (I, = 1) are both set, the 
resultant command would be HEX “DA”. The “OR” 
function is performed so that either a READY TO NOT- 
READY or the next Index Pulse will cause an interrupt 
condition. 


DATA RECOVERY 


Occasionally, the R/W head of the disk drive may get 
“off track”, and dust or dirt may get trapped on the 
media. Both of these conditions will cause a RECORD 
NOT FOUND and/or a CRC error to occur. This “soft 
error” can usually be recovered by the following 
procedure: 


1. Issue the command again 
2. Unload and load the head and repeat step 
3. Issue a restore, seek the track, and repeat step 1 


If RNF or CRC errors are still occurring after trying 
these methods, a “hard error” may exist. This is usu- 
ally caused by improper disk handling, exposure to 
high magnetic fields, etc. and generally results in de- 
stroying portions or tracks of the diskette. 
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FIGURE 1 DEVICE CHARACTERISTICS 
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FIGURE 2 STORAGE CAPACITIES 
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DENSITY 


SINGLE 3125 109,375° 80,640 
6250 218,750 161,280 
3125 218,750 161,280 
6250 437,500 322,560 
5208 401,016 256,256 

10,416 802,032 512,512 
5208 802,032 512,512 

10,416 1,604,064 1,025,024 


DOUBLE 
SINGLE 
DOUBLE 
SINGLE 
DOUBLE 
SINGLE 
DOUBLE 
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“Based on 35 Tracks/Side 
**Based on 18 Sectors/Track (128 byte/sec) 
***Based on 18 Sectors/Track (256 bytes/sec) 
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Features 


2001-0210, 0211 


CONTROL 


1 The instruction set contains 158 instructions. 


The 78 instructions of the 8080A are 
included as a subset; 8080A software com- 
patibility is maintained. 


g@ Six MHz, 4 MHz and 2.5 MHz clocks for the 


Z80B, Z80A, and Z80 CPU result in rapid 
instruction execution with consequent high 
data throughput. 


& The extensive instruction set includes string, 


bit, byte, and word operations. Block 
searches and block transfers together with 
indexed and relative addressing result in 
the most powerful data handling capabilities 
in the microcomputer industry. 


© The Z80 microprocessors and associated 


family of peripheral controllers are linked 
by a vectored interrupt system. This system 
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Figure 1. Pin Functions 
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may be daisy-chained to allow implemen- 
tation of a priority interrupt scheme. Little, 
if any, additional logic is required for 
daisy-chaining. 

@ Duplicate sets of both general-purpose 
and flag registers are provided, easing 
the design and operation of system soft- 
ware through single-context switching, 
background-foreground programming, and 
single-level interrupt processing. In addi- 
tion, two 16-bit index registers facilitate 
program processing of tables and arrays. 


B® There are three modes of high speed inter- 
rupt processing: 8080 compatible, non-Z80 
peripheral device, and Z80 Family 
peripheral with or without daisy chain. 


f& On-chip dynamic memory refresh counter. 
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Figure 2. Pin Assignments 
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General 
Description 


The Z80, Z80A, and Z80B CPUs are third- 
generation single-chip microprocessors with 
exceptional computational power. They offer 
higher system throughput and more efficient 
memory utilization than comparable second- 
and third-generation microprocessors. The 
internal registers contain 208 bits of read/write 
memory that are accessible to the programmer. 
These registers include two sets of six general- 
purpose registers which may be used 
individually as either 8-bit registers or as 
16-bit register pairs. In addition, there are two 
sets of accumulator and flag registers. A group 
of “Exchange” instructions makes either set of 
main or alternate registers accessible to the 
programmer. The alternate set allows operation 
in foreground-background mode or it may 
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be reserved for very fast interrupt response. 

The Z80 also contains a Stack Pointer, Pro- 
gram Counter, two index registers, a Refresh 
register (counter), and an Interrupt register. 
The CPU is easy to incorporate into a system 
since it requires only a single +5 V power 
source, all output signals are fully decoded 
and timed to control standard memory or 
peripheral circuits, and is supported by an 
extensive family of peripheral controllers. The 
internal block diagram (Figure 3) shows the 
primary functions of the Z80 processors. 
Subsequent text provides more detail on the 
Z80 I/O controller family, registers, instruction 
set, interrupts and daisy chaining, and CPU 
timing. 
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Figure 3. Z80 CPU Block Diagram 
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Z80 Micro- 
processor 
Family 


The Zilog Z80 microprocessor is the central 
element of a comprehensive microprocessor 
product family. This family works together in 
most applications with minimum requirements 
for additional logic, facilitating the design of 
efficient and cost-effective microcomputer- 
based systems. 

Zilog has designed five components to pro- 
vide extensive support for the Z80 micro- 
processor. These are: 


@ The PIO (Parallel Input/Output) operates in 
both data-byte I/O transfer mode (with 
handshaking) and in bit mode (without 
handshaking). The PIO may be config- 
ured to interface with standard parallel 
peripheral devices such as printers, 
tape punches, and keyboards. 


g@ The CTC (Counter/Timer Circuit) features 
four programmable 8-bit counter/timers, 


each of which has an 8-bit prescaler. Each 
of the four channels may be configured to 
operate in either counter or timer mode. 


@ The DMA (Direct Memory Access) con- 
troller provides dual port data transfer 
operations and the ability to terminate data 
transfer as a result of a pattern match. 


M The SIO (Serial Input/Output) controller 
offers two channels. It is capable of 
operating in a variety of programmable 
modes for both synchronous and asyn- 
chronous communication, including 


Bi-Synch and SDLC. 
The DART (Dual Asynchronous Receiver/ 


Transmitter) device provides low cost 
asynchronous serial communication. It has 
two channels and a full modem control 
interface. 


Z80 CPU 
Registers 
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Figure 4 shows three groups of registers 
within the Z80 CPU. The first group consists of 
duplicate sets of 8-bit registers: a principal set 
and an alternate set (designated by ' [prime], 
e.g., A‘). Both sets consist of the Accumula- 
tor Register, the Flag Register, and six 
general-purpose registers. Transfer of data 
between these duplicate sets of registers is 
accomplished by use of Exchange” instruc- 
tions. The result is faster response to interrupts 
and easy, efficient implementation of such ver- 
satile programming techniques as background- 
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~-_—— 8 BITS —_—_————— 
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IX INDEX REGISTER 
ty INDEX REGISTER 
SP STACK POINTER 


PC PROGRAM COUNTER 


t INTERRUPT VECTOR R MEMORY REFRESH 
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foreground data processing. The second set of 
registers consists of six registers with assigned 
functions. These are the I (Interrupt Register), 


the R (Refresh Register), the IX and IY (Index 


Registers), the SP (Stack Pointer), and the PC 
(Program Counter). The third group consists of 
two interrupt status flip-flops, plus an addi- 
tional pair of flip-flops which assists in identi- 
fying the interrupt mode at any particular 
time. Table | provides further information on 
these registers. 
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Figure 4. CPU Registers 
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Z80 CPU Register Size (Bits) Remarks 


Registers 
. A, A’ t ; 
(Continued) Accumulator 8 Stores an operand or the results of an operation 

F, F’ Flags 8 See Instruction Set. 

B, B’ General Purpose 8 Can be used separately or as a 16-bit register with C. 

Cc, Cc’ General Purpose 8 See B, above. 

D, D’ General Purpose 8 Can be used separately or as a 16-bit register with E. 

E, E' General Purpose 8 See D, above. 

H, H’ General Purpose 8 Can be used separately or as a 16-bit register with L. 

L, L’ General Purpose 8 See H, above. 

Note: The (B,C), (D,E), and (H,L) sets are combined as follows: 
B — High byte C — Low byte 
D — High byte E— Low byte 
H — High byte L— Low byte 

I Interrupt Register 8 Stores upper eight bits of memory address for vectored interrupt 
processing. 

R Refresh Register 8 Provides user-transparent dynamic memory refresh. Automatically 
incremented and placed on the address bus during each 
instruction fetch cycle. 

IX Index Register 16 Used for indexed addressing. 

IY Index Register 16 Same as IX, above. 

SP Stack Pointer 16 Stores addresses or data temporarily. See Push or Pop in instruc- 
tion set. 

PC Program Counter 16 Holds address of next instruction. 

IFF)-IFF Interrupt Enable Flip-Flops Set or reset to indicate interrupt status (see Figure 4). 

IMFa-IMFb _ Interrupt Mode Flip-Flops Reflect Interrupt mode (see Figure 4). 

Table 1. Z80 CPU Registers 
Interrupts: The CPU accepts two interrupt input signals: @ Mode 1 — Peripheral Interrupt service, for 
General NMI and INT. The NMI is a non-maskable use with non-8080/Z80 systems. 


Operation interrupt and has the highest priority. INT is a m Mode 2 — a vectored interrupt scheme 
lower priority interrupt since it requires that ‘ 
interrupts be enabled in software in order to 
operate. Either NMI or INT can be connected 
to multiple peripheral devices in a wired-OR 
configuration. 

The Z80 has a single response mode for 
interrupt service for the non-maskable inter- 
rupt. The maskable interrupt, INT, has three 
programmable response modes available. 
These are: 


@ Mode 0 — compatible with the 8080 micro- 
processor. 


usually daisy-chained, for use with Z80 
Family and compatible peripheral devices. 


__The CPU services interrupts by sampling the 
NMI and INT signals at the rising edge of the 
last clock of an instruction. Further interrupt 
service processing depends upon the type of 
interrupt that was detected. Details on inter- 
rupt responses are shown in the CPU Timing 
Section. 


Interrupts: 
Goneral 
Operation 
(Continued) 


Non-Maskable Interrupt (NMI). The non- 
maskable interrupt cannot be disabled by pro- 
gram control and therefore will be accepted at 
at all times by the CPU. NMI is usually 
reserved for servicing only the highest priority 
type interrupts, such as that for orderly shut- 
down after power failure has been detected. 
After recognition of the NMI signal (providing 
BUSREQ is not active), the CPU jumps to 
restart location OO66H. Normally, software 
starting at this address contains the interrupt 
service routine. 


Maskable Interrupt (INT). Regardless of the 
interrupt mode set by the user, the Z80 
response to a maskable interrupt input follows 
a common timing cycle. After the interrupt has 
been detected by the CPU (provided that 
interrupts are enabled and BUSREQ is not 
active) a special interrupt processing cycle 
begins. This is a special fetch (M1) cycle in 
which IORQ becomes active rather than 
MREQ, as ina normal M1 cycle. In addition, 
this special M1 cycle is automatically extended 
by two WAIT states, to allow for the time 
required to acknowledge the interrupt request 
and to place the interrupt vector on the bus. 


Mode 0 Interrupt Operation. This mode is 
compatible with the 8080 microprocessor inter- 
rupt service procedures. The interrupting 
device places an instruction on the data bus, 
which is then acted on six times by the CPU. 
This is normally a Restart Instruction, which 
will initiate an unconditional jump to the 
selected one of eight restart locations in page 
zero of memory. , 


Mode 1 Interrupt Operation. Mode 1 oper- 
ation is very similar to that for the NMI. The 
principal difference is that the Mode 1 inter- 
rupt has a vector address of 0038H only. 


Mode 2 Interrupt Operation. This interrupt 
mode has been designed to utilize most effec- 
tively the capabilities of the Z80 microproc- 
essor and its associated peripheral family. The 
interrupting peripheral device selects the 
starting address of the interrupt service 
routine. It does this by placing an 8-bit 
address vector on the data bus during the 
interrupt acknowledge cycle. The high-order 
byte of the interrupt service routine address is 
supplied by the I (Interrupt) register. This flex- 
ibility in selecting the interrupt service routine 
address allows the peripheral device to use 
several different types of service routines. 
These routines may be located at any available 


location in memory. Since the interrupting 
device supplies the low-order byte of the 
2-byte vector, bit 0 (Ag) must be a zero. ° 


Interrupt Priority (Daisy Chaining and 
Nested Interrupts). The interrupt priority of 
each peripheral device is determined by its 
physical location within a daisy-chain config- 
uration. Each device in the chain has an inter- 
rupt enable input line (JET) and an interrupt 
enable output line (IEO), which is fed to the 
next lower priority device. The first device in 
the daisy chain has its IE] input hardwared to 
a High level. The first device has highest 
priority, while each succeeding device has a 
corresponding lower priority. This arrange- 
ment permits the CPU to select the highest 
priority interrupt from several simultaneously 
interrupting peripherals. 

The interrupting device disables its IEO line 
to the next lower priority peripheral until it has 
been serviced. After servicing, its IEO line is 
raised, allowing lower priority peripherals to 
demand interrupt servicing. 

The Z80 CPU will nest (queue) any pending 
interrupts or interrupts received while a 
selected peripheral is being serviced. 


Interrupt Enable/Disable Operation. Two 
flip-flops, IFF; and IFF2, referred to in the 
register description are used to signal the CPU 
interrupt status. Operation of the two flip-flops 
is described in Table 2. For more details, refer 
to the Z80 CPU Technical Manual and 280 
Assembly Language Manual. 


Action IFF, IFF2 Comments 
CPU Reset 0 0 Maskable interrupt 
INT disabled 
DI instruction 0 0 Maskable interrupt 
execution INT disabled 
EI instruction 1 ] Maskable interrupt 
execution INT enabled 
LD A,] instruction e ° IFFy — Parity flag 
execution 
LD A,R instruction ° e IFF2 — Parity flag 
execution 
Accept NMI O IFF, IFF, — IFFo 
(Maskable inter- 
rupt INT disabled) 
RETN instruction IFF2 IFF2 — IFF) at 
execution completion of an 
NMI service 
routine. 


Table 2. State of Flip-Flops 
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Instruction The Z80 microprocessor has one of the most O 16-bit arithmetic operations 
werful and ile instruction sets : 
Set pow versatile nst uction 4 ‘Rotatesand shilts 
available in any 8-bit microprocessor. It 
includes such unique operations as a block O Bit set, reset, and test operations 
move for fast, efficient data transfers within 0 Jumps 
memory or between memory and I/O. It also 
Y ies apie O Calls, returns, and restarts 
allows operations on any bit in any location in 
memory. O Input and output operations 
The following is a summary of the Z80 A variety of addressing modes are 
instruction set and shows the assembly implemented to permit efficient and fast data 
language mnemonic, the operation, the flag transfer between various registers, memory 
status, and gives comments on each instruc- locations, and input/output devices. These 
tion. The Z80 CPU Technical Manual addressing modes include: 
(03-0029-01) and Assembly Language CO Immediate 
Programming Manual (03-0002-01) contain 
significantly more details for programming 0 Immediate extended 
use. O Modified page zero 
The instructions are divided into the ; 
; . OD Relative 
following categories: 
’ 0 e 
0 8-bit loads Extended 
P O Indexe 
D 16-bit loads pideree 
D Register 
0 Exchanges, block transfers, and searches gist 
F ‘ : : : O Register indirect 
O 8-bit arithmetic and logic operations Register indire 
ae ; Oo i 
O General-purpose arithmetic and CPU Implied 
control D Bit 
8-Bit Symbolic | Flags Opcode No.of No.of M No.of T 
Load Mnemonic Operation 4 iH P/V N C 76 543 210 Hex Bytes Cycles States Comments 
Group LDr, r' rer’ X ¢ KX © © ¢ Or fr 1 1 4 rr oR 
LDr,n r-n ee X¥ ,* X © @ «¢ o r 110 2 2 7 o00.-—=Cti*#&j® 
aes 001 «Cc 
LDr, (HL) sr — (HL) . Xe X © © © Or illo 1 2 7 ol0 D 
LDr, (IX+d) rr — (IK+d) ° X X e© e © 10101 DD 3 5 19 oll o£ 
Ol r 10] 100 +H 
sa 101 
LDr, (I¥+d)  r—(IY+d) * 6 X © X © © © WINi0l FD 3 5 19 oA 
Ol r lo 
d= 
LD(HL),r 9 (HL) =r Xe X © ¢ © OllOr 1 2 7 
LD(IX+d),r  (IX+d)—r Xe X * © 1012101 DD 3 5 19 
01 110 r 
Sidi 
LD(IY+d),r (IY+d)—r ° * X © X © © © diliol FD 3 5 19 
01 110 r 
ed 
LD(HL),n (HL) =n eo 6 X © X © © © 11011036 2 3 10 
-—n—- 
LD(IX+d),n (IX+d)—n * + X © X © © © olliol DD 4 5 19 
00 110 110 36 
o-dea 
Sains 
LD(Y+d),n (IY+d)—n e+ X © X © ¢ © Uiio FD 4 5 19 
00 110 110 36 
d= . 
-n—- : 
LDA,(BC) A —(BC) eo 6 X © X © © © MOOOO1IO CA 1 2 7 
LDA,(DE) A (DE) eo 8 X © X © © © OOOlOlO 1A 2 2 7 
LDA, (nn) A = (nn) e+ X © X © © © O10lIO 3A 3 4 13 
sects 
john 
LD(BC),A (BC) A X X * +» 0o0I0 02 1 2 7 
LD(DE),A (DE) —A X © X © © © ooo 12 1 2 7 
LD(nn),A (nn) —A X X © © © 110010 32 3 4 13 
aeen 
a hie 
LDA, 1 Riot 1 1 X 0 X IFFO ¢ 11101101 ED 2 2 9 
01 010 111 57 
LD A,R A-R 1 t X 0 X IFF 0 * 11101101 ED 2 2 9 
01011 111 SF 
LDILA I-A ee X © X © e© © 21101101 ED 2 2 9 
01000111 47 
LDR, A R-A eo + X © X © © © 11101101 ED 2 2 9 
01 001 111 4F 


NOTES: r, r' means any of the registers A, B, C, D, E, H, L. 
IFF the content of the interrupt enable flip-flop, (IFF) is 
copied into the P/V flag. 
For an explanation of flag notation and symbols for 
mnemonic tables, see Symbolic Notation section 
following tables. 
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16-Bit Load Symbolic gs Opcode No.of No.of M No.of T 
Gr oup Mnemonic Operation P/V N C 76 S43 210 Hex Bytes Cycles States Comments 
LD dd, nn dd = nn xX X * @ @ 00 ddO 001 3 3 10 dd Pair 
-a- 00 BC 
-na- 0) DE 
LD IX, nn IX = nn xX xX © @¢ @ 11 011 101 DD 4 4 14 10 HL 
00 100 001 2) 1 SP 
-n— 
—n-- 
LD IY, nn ly = nn x X * @ @ 1): 111 101 FD 4 4 14 
00 100 00! 21 
-n- 
-~n- 
LD HL, (nn) H = (nn+1}) xX X ¢© @ @ 00 101 010 2A 3 5 16 
L — (nn) -ne 
-n- 
LD dd, (nn) ddy — (nn+1) x X © e@ 6 11 101 101 ED 4 6 20 
ddy, — (nn) 01 dd} 011 
-n—- 
-n-—- 
LD IX, (nn) IXy = (nn+1) x X ¢ ¢ @ 11 011 101 DD 4 6 20 
IXp — (nn) 00 101 010 2A 
-n—- 
-n- 
LD IY, (nn) TYy — (nn +1) x X * @ @ 11 111 101 FD 4 6 20 
IYp = (nn) 00 101 010 2A 
: Se 
—-rn— 
LD (nn), HL (nn+1)-—H x X ¢ @ @ 00 100 010 22 3 5 16 
{nn) -— L “n= 
-a- 
LD (nn), dd (nn+]) — ddy xX Xx * e e 11 101 101 ED 4 6 20 
(nn) -— ddp Ol ddO 011 
-n- 
-—n— 
LD (nn), IX (nn+1) — Xyq x X ¢ ee @ 11 012 101 DD 4 6 20 
(nn) — IXp 00 100 010 22 
a7 
apy aes 
LD (nn), IY (nn+1) - IYy xX X * @ @ 11 112 101 FD 4 6 20 
(nn) - IYp 00 100 010 22 
-—na— 
= pees 
LD SP, HL SP -— HL x Xx 8 @¢ 11 112 001 F9 1 1 6 
LD SP, IX SP = IX x xX * @e e@ 11 011 101 DD 2 2 10 
11 111 001 F9 
LD SP, IY SP = IY xX xX * © @ 11 111 101 FD 2 2 10 
11 111 001 F9 qq Pair 
PUSH aq (SP-2) — qqL x xX ee ee @ 11 qq 101 1 3 li 00 BC 
(SP-1) — qqy 01 DE 
SP — SP -2 10 - HL 
PUSH IX (SP-2) — IX, x X * # @ 4] 011 101 DD 2 4 15 1] AF 
(SP-1) — IXy 11 100 101 ES 
SP — SP -2 
PUSH IY (SP-2) — IY, x X * ee e 1} 112 10] FD 2 4 15 
(SP-1) — IYy 11 100 101 £5 
SP ~ SP -2 
POP qq aqy — (SP +1) x X * @ e 11 qgO 001 1 3 10 
gaz - (SP) 
SP — SP +2 
POP IX IXy — (SP +1) x X 8 e @ 11 O11 101 DD 2 4 14 
IXy — (SP) 11 100 001 E) 
SP ~ SP +2 
POP IY I¥y — (SP +1) 4 X © @# e 11 111 101 FD 2 4 14 
T¥r — (SP) 11 100 001 El 
SP — SP +2 
NOTES: dd is any of the register pairs BC, DE, HL, SP. 
qq is any of the register pairs AF, BC, DE, HL. 
(PAIR)y, (PAIR)L refer to high order and low order eight bits of the register pair respectively, 
e.g., BCp = C, AFy = A. 
Exchange, EX DE, HL DE ~ HL xX X ¢© @ e 1] 101 011 EB 1 1 4 
Block EX AF, AF’ AF ~ AF’ x X * @ @ 00 001 000 08 1 1 4 
EXX BC ~ BC’ xX X © e @ 1] 011 001 D9 1 1 4 Register bank and 
Transfer, DE ~ DE’ auxiliary register 
HL = HL’ bank exchange 
Block Search gx isp uy = (SP +1) x Xe 6 ¢ 1100011 3 2 5 19 
Groups L ~ (SP) 
EX (SP), IX IXy ~ (SP+1) x X © © @ 11 011 101 DD 2 6 23 
Xp ~ (SP) 11 100 011 E3 
EX (SP), IY TYy -~ (SP +1) xX X e© e @ 1] 111 101 FD 2 6 23 
IY, = (SP) 1) 100 011 E3 
LDI (DE) — (HL) x x QO °¢ 11 101 101 ED 2 4 16 Load (HL) into 
DE — DE+1 10 100 000 AO (DE), increment 
HL — HL+1 the pointers and 
BC — BC-1 decrement the byte 
counter (BC) 
LDIR (DE) = (HL) xX X. oe 11 101 101 ED 2 5 21 IfBC #0 
DE — DE+1 10 110 000 BO 2 4 16 If BC =0 
HL — HL+1 
BC - BC-1 
Repeat until 
BC =0 


NOTE: Orv flag is 0 if the result of BC-1 = 0, otherwise P/V = 1. 
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Exchange, 
Block 
Transfer, 
Block Search 
Groups 
(Continued) 


8-Bit 
Arithmetic 
and Logical 
Group 


Symbolic Flags Opcode No.of No.of M No.of T 
Mnemonic Operation ae 4 H P/V N C 76 $43 210 Hex Bytes Cycles States Comments 
@ 
LDD (DE) — (HL) “26 X OX t O @ 11101101 ED 2 4 16 
DE — DE-1 10 101 000 A8 
HL — HL-1 
BC — BC-1 
LDDR (DE) — (HL) ee X 0 X¥ 00 e 11101101 ED 2 5 21 IBC #0 
DE — DE-1 ; 10111 000 B82 4 16. IfBC=0 
HL — HL~1 
BC —BC-1 
Repeat until 
BC =0 
@ ® 
CPI A - (HL) tot Xr X t tie 11101101 ED 2 4 16 
HL — HL+1 10 100 001 Al 
BC - BC-} 
@ 0) 
CPIR A ~ (HL) tor xX ¢: X t 1 e 11101101 ED 2 5 21 It BC # O and 
A # (HL) 
HL - HL+} 10 110 00! Bi 2 4 16 If BC = Oor 
BC — BC-1 A = (HL) 
Repeat until 
A = (HL) or 
BC =0 
@ 10} 
CPD A - (HL) 2 Kate CXS Ate ee 11161101 ED 2 4 16 
HL — HL-1 10 101 001 AQ 
BC — BC-1 
2) ® 
CPDR A - (HL) (Of Ke spk ap xe 11101101 ED 2 5 21 If BC # Oand 
A # (HL) 
HL — HL-1 10111 001 B92 4 16 If BC = Oor 
BC — BC-1 A = (HL) 
Repeat until 
A = (HL) or 
BC =0 
NOTES: @ P/V flag is O if the result of BC-1 = 0, otherwise P/V = 1. 
@z flag is 1 if A = (HL), otherwise Z = 0. 
ADD A, r A-A+r tot X + X¥ V O ft 10 ROG] r 1 1 4 r Reg. 
ADD A, n A-At+n tor Xr X¥ Vo Oo 8 1) Od) 110 2 2 7 000 B 
-n- 001 C 
010 D 
ADD A, (HL) A -—A + (HL) ft 2X -h -H ‘Weoo 4 10 [609] 110 1 2 7 C11 E 
ADD A, (IX+d) A - A + (IX+d) tor X ¢ X VO 48 11011101 DD 3 5 19 100 H 
10 [000] 110 101 L 
e+ d- Hl A 
ADD A, (I¥+d) A~ A+ (IY +d) tor xX t+ X¥ V Of 1111101 FD 3 5 19 
10 (00d) 110 
-d- 
ADC A, s A-Ats+CY tor xX t X¥ Vi Of s is any of r, n, 
SUB A-A ' xt Xvi Lt een 
5 ei ' (IY +d) as shown 
SBC A, s A —A-s-CY tor X t X Voi. for ADD instruction. 
AND s A-AAs 14 X 1 X PO O fog ie ore 
replace the in 
ons BUR Bo ame ie a BO 0 the ADD set above. 
XOR s A-Aes rt r+ X¥ O X P OO (oy 
CP s A-s tot X ¢ X¥ Voi | 
INC r r-r¢] t t X t+ X¥ VO ®@ oo r [100 ] ] 4 
INC (HL) (HL) —(HL)+1 tor X t X Vi Oe oo 110 [fod 1 3 1h 
INC (IX+d) (IX+d) — tr X t+ X V Oe 11011 101 DD 3 6 23 
(IX+d)+]1 00 110 {10g} 
= d= 
INC (IY+d) (IY +d) = to6 X t X Vi Oe 1h1ll 101 FD 3 6 23 
(IY +d) +1 00 110 [0 
-d-— 
DEC m m-m-! torxX t X Vie fo) m is any of r, (HL), 


(IX +d), (IY +d) 
as shown for INC. 
DEC same format 
and states as INC. 
Replace with 
in opcode. 
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General- Symbolic Fla Opcode No.of No.of M No.of T 

Purpose Mnemonic Operation 8s Z H P/V N C 78 $43 210 Hex Bytes Cycles States Comments 

Arithmetic DAA Convertsacc. content $! $! X t! X P ®# ¢f 00 100 111 27 1 1 4 Decimal adjust 

into packed BCD accumulator, 
and following add or 
subtract with packed 

CPU Control BCD operands, 

Groups CPL A-A * © X 1X © 1 © oO10l1 2F 1 l 4 Complement 
accumulator (one’s 
complement). 

NEG A-O-A t t X t+ X¥ Vd s4 11 10] 10) ED 2 2 8 Negate acc. (two’s 
res 01 000 100 44 complement). 
CCF CY —CY ee X¥ X X *© O 4 00 111 111 3F 1 ! 4 Complement carry 
flag. 
SCF CY -1 > e¢ X 0 X © 0 1 00 110 11] 37 1 1 4 Set carry flag. 
NOP No operation ee X © X #© © @ 00 000 000 00 1 1 4 
HALT CPU halted ee X © X # © @ 01 110 110 76 1 1 4 
DI « IFF —0 ee X © KX e @ © 11,110 011 F3 1 1 4 
El IFF — 1 ee X © X © © © 1111) 011 FB 1 1 4 
IM 0 Set interrupt * e©« X © X ee © e 1) 10) 101 ED 2 2 8 
mode 0 01 000 110 46 
IM 1 Set interrupt oe X © X © © «© 11 101 101 ED 2 2 8 
mode 1 01 010 110 56 
IM 2 Set interrupt se X © X # e# @ 1) 101 101 ED 2 2 8 
mode 2 01 011 110 5E 
NOTES: _IFF indicates the interrupt enable flip-flop. 
CY indicates the carry flip-flop. 
* indicates interrupts are not sampled at the end of El or DI. 
16-Bit ADDHL,ss HL — HL+ss * © X X X © O ¢ ssl 001 1 3 1 ss_Reg. 

: : 00 BC 
Arithmetic ADCHL,ss HL—HL+ss+CY 1 + X X X VO ¢ Jl lolol ED 2 4 15 01 DE 
Group Ol ssl 010 10 HL 

: 11 SP 
SBC HL, ss HL — HL-ss-CY to Oe SE ON GE 11 101 101 ED 2 4 15 
QO! ssO 010 
ADD IX, pp IX — IX + pp ee“ 6©« X X X * 0 1 11 011 101 DD 2 4 1S pp__ Reg 
01 ppl 00) 00 BC 
Ol DE 
10 IX 
1] SP 
ADD IY, rr TY —lY + rr ee X KX X ¢« O 3 1] 111 10! FD 2 4 15 rr Reg 
00 rrl 001 00 BC 
01 DE 
10 IY 
11 SP 
INC ss ss— ss + ] X ¢ X ®@ ° 00 ssO 0}1 1 1 6 
INC IX IX - IX + 1 X ¢ X @ . 11 011 101 DD 2 2 10 
00 100 O11 23 
INC IY Iy-lY + 1 e 28 KX © KX @e e @ 1] 111 101 FD 2 2 10 
00 100 011 23 
DEC ss ss ~— ss-l oe 8 X xX ° 00 ssl O11 1 1 6 
DEC IX IX — IX-1 eo «6 X x ° 1] O11 101 DD 2 2 10 
00 101 011 2B 
DEC IY IY -—1lY-1 eo 2© X © X # # @ 11 111 101 FD 2 z 10 
00 101 011 2B 
NOTES: ss is any of the register pairs BC, DE. HI. SP. 
pp is any of the register pairs BC, DE, JX. SP. 
rris any of the register pairs BC, DE, IY, SP. 
Rotate and — 
Shift Group —-BLCA toast wk xe 0) mom 4 Rotate left circular 
A accumulator. 
RLA Urey — 70} * © X 0 X © O +: OOlOIN 17 4 Rotate left 
A accumulator. 
RRCA ee X O0 X © O 4 00 001 111 OF 4 Rotate right circular 
A accumulator. 
RRA {7—-0 | \* 6 X 0 X © 0 3% 00 Oll 11 OIF 4 Rotate right 
A accumulator, 
RLC r t + X O X P O 1% 11 001 011 CB 8 Rotate left circular 
Q 000 r register r. 
RLC (HL) t + X O X P O14 11 601 O11 CB 15 wo : : 
00 000 110 aol OG 
acux+a }MI-A=—o} gy x 0 xP 0d) oma DD a Oe oe 
r,(HL).(IX +d), (IY +d) 11 001 011 CB 100 H 
ee lol ok 
00 000 110 ne] A 
RLC (IY +d) 1 t X O X P O 41 11 11) 101 FD 23 
11 001 O11 - CB 
eS Instruction format 
= 00 000 110 and states are as 
RL m kare. tor X 0 X PO 4 010 shown fer RLC’s. 
matr,(HL),(IX + d), (IY +d) To form new 
opcode replace 
RRC m 11 X 0X POY 001 000 or RLC’s 


mam r,(HL),(IX + d),(1Y + d) 


with shown code. 
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Rotate and Symbolic Flags Opcede No.of No.of M No.of T 
Shift Group _ Mnemonic Operation 8s Z H P/V N C 76 543 210 Hex Bytes Cycles States Comments 
Continued 
: ee er 
mar,(HL),(IX +d), (IY +d) 
SLA m (er]-—_{ z= } + X OX POY 
mur,(HL),(IX +d), (IY +d) 
SRA m ee tor X Oo X PO 4% 
mar,(HL) (IX +d), (IY +d) 
SRL m o-{(7—=o }—-[eYF] + 3} X OX POG (m7) 
marr,(HL),(IX +d),(IY +) 
RLD [7-473 -0] tot X¥ 0 X PO ¢ 101101 ED 2 5 18 Rotate digit left and 
ame O01 101 111 6F right between 
the accumulator 
and location (HL). 
RRD [7-4]3-0]—~[7-4]9-0] } y X O X P O © 11101101 ED 2 5 18 The content of the 
A HD 0) 100 111 =67 upper half of 
the accumulator is 
unaffected. 
Bit Set, Reset sitp,r Z-tb X t+ X 1 X X G e* W001011CB. 2 2 8 r__ Reg. 
and Test = Osea Us 00 B 
BIT b, (HL) Z — (HL)p X 1 X 1 X KX O @ 1] 001 011 CB 2 3 12 001 Cc 
Group 01 b 110 010 D 
BIT b, (IX+d)p Z = (IX+d)p X 1 X 1 X X 0 @ 11 011 101 DD 4 5 20 oll E 
11 001 011 CB 100 H 
-~-d- 101 L 
01 b 110 llt A 
: b Bit Tested 
BIT b, (IY +d)p Z — (IY +d)p X t+ X 1 X X O @ 11 111 101 FD 4 5 20 000 0 
11 001 011 CB ool 1 
-~d- 010 2 
Ol b 110 oll 3 
100 4 
101 5 
110 6 
lll 7 
SET b.r ihe 1 eo e¢ X © X © e@ @ 11 001 011 CB 2 2 8 
; im) b tr 
SET b, (HL) (HL)p - 1 oe X © X © © «@ 11 00) O11 CB 2 4 15 
M7 b» io 
SET b, (IX+d) (IX+d), — 1 ee X © X & @ @ 11 011 101 DD 4 6 23 
11 001 011 CB 
eq. Ss 
{] b 10 
SET b, (I¥+d) (IY¥+d),p- 1 ee X © X * @ 8 11 111 10] FD 4 6 23 
1] 001 011 CB 
dil 
[ b 10 
RES b, m Mp - 0 ee X © X # # © fig To form new 
m= r, (HL), opcode replace 
(IX+d), [1} of SET b, 
dy +d) with [[Q}. Flags 
and time states for 
SET instruction. 
NOTES: The notation mp indicates bit b (0 to 7) or location m. 
Jump JP nn PC — nn ee X © X © © © 1] 000 O11 C3 3 3 10 
Be 
Group -n- cc Condition 
JP ec, nn If condition ce is eo 28 X «© X © ee @ 1) ce 010 3 3 10 000 NZ non-zero 
true PC — nn, - no 001 Z~= zero 
otherwise - nA 010 NC non-carry 
continue 011 C carry 
100 PO parity odd 
101 PE parity even 
110 P sign positive 
Re PC -— PC+e eo e@« X © X © @ © 00 011 000 18 2 3 12 111 M_ sign negative 
= 22 — 
JR C,e IC = 0, eo © X © X © @ © 00 111 000 38 2 2 7 If condition not met. 
continue -e-2- 
HC. }, 2 3 12 If condition is met. 
PC - PC+e 
IR NC, e iC = 1, oe X © X © @ 6 00 110 000 30 2 2 7 If condition not met. 
continue -e-2- 
NC = 0, 2 3 12 If condition is met. 
PC ~ PC +e 
IPZ,e IfZ=0 ee X © X © © @ 00 101 000 28 2 2 7 If condition not met. 
continue -e-2- . 
"Z= 1, , 2 3 12 If condition is met. 
PC — PC+e 
JR NZ, e IfZ = 1, oe X © KX © © @ 00 100 000 20 2 2 7 If condition not met. 
continue -e-2- 
ifZ=0, 2 3 12 If condition is met. 
PC + PC+e 
JP (HL) PC — HL eo 2° X © X # @ «© 11 10) 001 E9 1 1 4 
JP (1X) PC — IX oe X @© K @ ee @ 11 011 101 DD 2 2 8 
11 101 00) E9 
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Jump Group Symbolic Flags Opcode No.of No.of M No.of T 


(Continued) Mnemonic Operation 8 2 H P/V N C 76 $43 210 Hex Bytes Cycles States Comments 
IP (IY) PC -— IY © © X¥ © X e @ « 1] 111 101 FD 2 2 8 
: 11 101 001 E9 

DINZ, e B-B-1 ° ee X © X © @ © 00 010 000 10 2 2 8 B= 0. 
UB = 0, -e-2— 
continue 
B20, ‘ 2 3 13 KB #0. 
PC — PC+e 


NOTES: e representa the extension in the relative addressing mode. 
@ ia a signed two's complement number in the range < -126, 129 >. 
@-2 in the opcode provides an effective address of pc +e as PC is incremented 
by 2 prior to the addition of e. 3 


Call and CALL nn (SP-1) — PCy eo Xe X © e e J1001101CD 3 5 17 
(SP-2) — PCL -1ra- 
Return Group Pe ae eh Se 
CALL ce, nn _If condition ee © X © X © © «@ ll cc 100 3 3 10 If cc is false. 
ce is false -rvA > 
continue, - rn 3 5 17 If cc is true. 
otherwise same as 
CALL nn 
RET PCL-(SP)" . ee X © X © © © LOlOICcO 1 3 10 
PCH — (SP+1) 
RET cc If condition oe X © X © © @ 31 cc 000 1 1 5 If cc is false. 
cc is false 
continue, 1 3 th If ce is true. 
dato ce Condition 
. 000 NZ non-zero 
oe 001 Z zero 
RETI Return from eo. Xe X © © © iiol10l ED 2 4 i oe 
interrupt 01 001 101 4D 100 PO sanity odd 
RETN! Return from *» © X «© X ¢ e e 11101101 ED 2 4 4401 PE Satity 
parity even 
non-maskable 01 000 101 45 110 P sign positive 
interrupt 111M. sign negative 
RST p * (SP-1) — PCy oe © X © X © @ 8 ll to dll l 3 i t Pp. 
(SP-2) — PCL 000 00H 
PCH — 0 001 08H 
PCL -p - 010 10H 
011 18H 
100 20H 
101 28H 
110 30H 
ll] 36H 
NOTE: 'RETN loads IFF2 ~ IFF, 
Input and IN A, (n) A -(n) \e + X © X © © e Liollol DB 2 3 N nto Ag ~ A7 
-aA = Acc. to Ag ~ Ajs 
Output Group 4, r= (C) tt X t X¥ PO * 11101101 ED 2 3 12 Clo Ag ~ A? 
ifr = 110 only the ; Ol r 000 ; B to Ag ~ Ajs 
flags will be affected 
INI (HL) = (C) xX t| X X X X 1 e 11 101 101 ED 2 4 16 Cto Ag ~ Az 
B-B-1 10 100 010 A2 Bto Ag ~ Ajs 
HL -— HL + 1 
INIR (HL) — (C) X 1 X X X X 1 ®@ 11 101 101 ED 2 5 21 CtoAg ~ A7 
B—B-1 10 110 010 B2 (If B#0) Bto Ag ~ Ajs 
HL — HL + 1 2 4 16 
Repeat until : (If B=0) 
B=0 : 
IND (HL) — (C) xX t X X X X 1 e@ 11 101 101 ED 2 4 16 C to Ag ~ Az 
B-B-1 10 101 010 AA Bto Ag ~ Ajs 
HL — HL-1 
INDR (HL) — (C) X 1 X X X X¥ 1 @ 11 101 101 ED 2 5 21 Cto Ag ~ Az 
B-B-1 10 111 010 BA (If B#0) Bto Ag ~ Ajs 
HL — HL-1! 2 4 16 
Repeat until (If B=0) 
B=0 
OUT (n), A (n)-A ee X © X # ee @ 11 010 O11 DI 2 3 ll nto Ag ~ Az 
-n- Acc. to Ag ~ Ajs 
OUT (C), r (C)-—r ee *¢ X © X © e @ 1! 101 101 ED 2 3 12 Cto Ag ~ Az 
01 r OOl Bto Ag ~ Aj5 
OUTI (C) — (HL) xX t! X X X X 1 e 11 101 101 ED 2 4 16 Cto Ag ~ Az 
B-B-1 10 100 011 A3 Bto Ag ~ Ajs ; 
HL — HL + 1 
OTIR (C) — (HL) X 1 X X X X 1 e 11 10) 101 ED 2 5 21 Cto Ag ~ A? 
B-B-1 10 110 011 B3 (If B#0) Bto Ag ~ Ajs 
HL — HL + 1 2 4 16 
Repeat until (If B=0) 
B=0 
OUTD (C) — (HL) X ! X X X X 1 e@ 11 101 101 ED 2 4 16 Cto Ag ~ Az 
B-B-1 10 101 011 AB Bto Ag ~ Ajs 
HL — HL-1 


NOTE: @ If the result of B-1 is zero the Z flag is set, otherwise it is reset. 


Q 
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No.of No.of M No.of T 


Input and : oe Symbolic Flags Opcode : 
Output Group Mnemonic Operation $8 z HH P/V N C = 76 S43 210 Hex Bytes Cycles States Comments 
(Continued) OTDR (C) ~ (HL) X 1 X X X X 1 ¢ 1110! 10! ED 2 5 21 C to Ag ~ Az 
B-B-} 10 111 011 (If B#0) Bto Ag ~ Ajs 
HL — HL-1 2 4 16 
Repeat «until (If B=0) 
B=0 
Summary of Dy Do 
Flag Instruction s Zz H P/V N C Comments 
Operation ADD A, s; ADC A, 8 1 t X t X VO ft — Bbitadd oradd with carry. 
'P . SUB s; SBCA, s; CP s; NEG t+ X ¢ X Vi I 4 8-bit subtract, subtract with carry, compare and negate accumulator. 
AND s ! t X 1 X P O O , ‘ 
OR s, XOR s 1 t X 0 X P 0. Of Logical operations. 
INC 8 t t+ X t X V O ®@ 8-bit increment. 
DEC s. t ¢ X t+ X Vi de 8-bit decrement. 
ADD DD, ss ee e©« X X X * 0 4 16-bit add. 
ADC HL, ss ' t X X X V Ot 16-bit add with carry. 
SBC HL, ss ' ¢$ X X X Vd s+4 16-bit subtract with carry. 
RLA, RLCA, RRA; RRCA ee ee X O X * O 4 Rotate accumulator. 
RL m; RLC m; RR m; t t+ X O xX P O +34 Rotate and shift locations. 
RRC m; SLA m; 
SRA m; SRL m 
RLD; RRD i ' X O xX P QO ® Rotate digit left and right. 
DAA : ' X tt X P ® 3% Decimal adjust accumulator. 
CPL e ee X 1 XK © 1 @ Complement accumulator. 
SCF ee 6©* X¥ 0 X ¢* 0 1 Set carry. 
CCF eo e@« X X X © O 1 Complement carry. 
IN r(C) rt t xX O KX P O * Input register indirect. 
INI, IND, OUTI; OUTD X t X X X X 1 @ 4 ; 
INIR: INDR; OTIR: OTDR xX 1 x xX X X) ) Block input and output. 2 = 0 if B # O otherwise Z = 0. 
TOLL EBDA a . : : : . *} Block transfer instructions. P/V = 1 if BC # 0, otherwise P/V = 0. 
CPI; CPIR; CPD; CPDR X 1 X XK X t 21 Block search instructions. Z = 1 if A = (HL), otherwise Z = 0. P/V = 1 
if BC # 0, otherwise P/V = 0, 
LDA,1, LDA, R { t X oO XX IFF oO e The content of the interrupt enable flip-flop (IFF) ts copied into the P/V flag. 
BIT b, s X°> t+ X 1 X X O ® The state of bit b of location s is copied into the Z flag. 
Symbolic _ Symbol Operation Symbol Operation 
Notation S Sign flag. S = 1 if the MSB of the result is 1. H The flag is affected according to the result of the 
Zero flag. Z = 1 if the result of the operation is 0. operation. 
P/V Parity or overflow flag. Parity (P) and overflow e The flag is unchanged by the operation. 
(V) share the same flag. Logical operations affect 0 The flag is reset by the operation. 
this flag with the parity of the result while 1 The flag is set by the operation. 
arithmetic operations affect this flag with the xX The flag is a “don't care.” 
overflow of the result. If P/V holds parity, P/V = Vv P/V flag affected according to the overflow result 
I if the result of the operation is even, P/V = 0 if of the operation. 
result is dd. If P/V holds overflow, P/V = 1 if Pp P/V flag affected according to the parity result of 
the resu': .{ the operation produced an overflow. the operation. 

7 H - Half-carr: ‘lag. H = 1 if the add or subtract r Any one of the CPU registers A, B, C, D, E, H, L. 
operatic: sroduced a carry into or borrow from 8 Any 8-bit location for all the addressing modes 
bit 4 of «+: accumulator. allowed for the particular instruction. 

N Add/Su'.” :ct flag. N = 1 if the previous opera- ss Any 16-bit location for all the addressing modes 
tion was .. subtract. allowed for that instruction. 

H&N_ Hand ‘gs are used in conjunction with the ii Any one of the two index registers IX or IY. 
decimai . ‘ust instruction (DAA) to properly cor- R Refresh counter. 
rect the ~~ .]t into packed BCD format following n 8-bit value in range < 0, 255 >. 
addition. . subtraction using operands with nn 16-bit value in range < 0, 65535 >. 
packed i-.0 format. 

Cc Carry/Li..: flag. C = 1 if the operation produced 
a carry f, .:n the MSB of the operand or result. 


16 
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Pin 
Descriptions 


Ao-Ajs5. Address Bus (output, active High, 
3-state). Ag-Aj5 form a 16-bit address bus. The 
Address Bus provides the address for memory 
data bus exchanges (up to 64K bytes) and for 
I/O device exchanges. 


BUSACK. Bus Acknowledge (output, active 
Low). Bus Acknowledge indicates to the 
requesting device that the CPU address bus, 
data bus, and control signals MREQ, IORQ, 
RD, and WR have entered their high- 
impedance states. The external circuitry 
can now control these lines. 


BUSREQ. Bus Request (input, active Low). 
Bus Request has a higher priority than NMI 
and is always recognized at the end of the cur- 
rent machine cycle. BUSREQ forces the CPU 
address bus, data bus, and control signals 
MREQ, IORQ, RD, and WR to go to a high- 
impedance state so that other devices can 
control these lines. BUSREQ is normally wire- 
ORed and requires an external pullup for 
these applications. Extended BUSREQ 
periods due to extensive DMA operations can 
prevent the CPU from properly refreshing 
dynamic RAMs. 


Do-Dy7. Data Bus (input/output, active High, 
3-state). Do-D7 constitute an 8-bit bidirectional 
data bus, used for data exchanges with 
memory and I/O. 


HALT. Halt State (output, active Low). HALT 
indicates that the CPU has executed a Halt 
instruction and is awaiting either a non- 
maskable or a maskable interrupt (with the 
mask enabled) before operation can resume. 
While halted, the CPU executes NOPs to 
maintain memory refresh. 


INT. Interrupt Request (input, active Low). 
Interrupt Request is generated by I/O devices. 
The CPU honors a request at the end of the 
current instruction if the internal software- 
controlled interrupt enable flip-flop (IFF) is 
enabled. INT is normally wire-ORed and 
requires an external pullup for these 
applications. 


IORQ. Input/Output Request (output, active 


Low, 3-state). IORQ indicates that the lower 
half of the address bus holds a valid I/O 


. address for an I/O read or write operation. 


TORQ is also generated concurrently with M1 
during an interrupt acknowledge cycle to indi- 
cate that an interrupt response vector can be 


placed on the data bus. 


Ml. Machine Cycle One (output, active Low). 
M1, together with MREQ, indicates that the 
current machine cycle is the opcode fetch 
cycle of an instruction execution. M1, together 
with IORQ, indicates an interrupt acknowledge 
cycle. 


MREQ. Memory Request (output, active 

Low, 3-state). MREQ indicates that the address 
bus holds a valid address for a memory read or 
memory write operation. 


NMI. Non-Maskable Interrupt (input, active 
Low). NMI has a higher priority than INT. NMI 
is always recognized at the end of the current 
instruction, independent of the 

status of the interrupt enable flip-flop, and 
automatically forces the CPU to restart at 
location 0066H. 


RD. Memory Read (output, active Low, 
3-state). RD indicates that the CPU wants to 
read data from memory or an I/O device. The 
addressed I/O device or memory should use 
this signal to gate data onto the CPU data bus. 


RESET. Reset (input, active Low). RESET 
initializes the CPU as follows: it resets the 
interrupt enable flip-flop, clears the PC and 
Registers I and R, and sets the interrupt status 
to Mode 0. During reset time, the address and 
data bus go to a high-impedance state, and all 
control output signals go to the inactive state. 
Note that RESET must be active for a minimum 
of three full clock cycles before the reset 
operation is complete. 


RFSH. Refresh (output, active Low). RFSH, 
together with MREO, indicates that the lower 
seven bits of the system's address bus can be 
used as a refresh address to the system's 
dynamic memories. 


WAIT. Wait (input, active Low). WAIT 
indicates to the CPU that the addressed mem- 
ory or I/O devices are not ready for a data 
transfer. The CPU continues to enter a Wait 
state as long as this signal is active. Extended 
WAIT periods can prevent the CPU from 
refreshing dynamic memory properly. 


WR. Memory Write (output, active Low, 
3-state). WR indicates that the CPU data bus 
holds valid data to be stored at the addressed 
memory or I/O location. 


Ws 


dd 08Z 


CPU Timing 


The Z80 CPU executes instructions by pro- 
ceeding through a specific sequence of opera- 
tions: 


@ Memory read or write 
m I/O device read or write 


@ Interrupt acknowledge 


The basic clock period is referred to as a 
T time or cycle, and three or more T cycles 
make up a machine cycle (M1, M2 or M3 for 
instance). Machine cycles can be extended 
either by the CPU automatically inserting one 
or more Wait states or by the insertion of one 
or more Wait states by the user. 


Instruction Opcode Fetch. The CPU places 
the contents of the Program Counter (PC) on 
the address bus at the start of the cycle (Figure 
5). Approximately one-half clock cycle later, 
MREQ goes active. The falling edge of MREQ 
can be used directly as a Chip Enable to dyna- 
mic memories. When active, RD indicates that 


‘the memory data can be enabled onto the CPU 


CLOCK 


Ao-Ais 


NOTE: T,-Wait cycle added when necessary for slow ancilliary devices. 


data bus. 

The CPU samples the WAIT input with the 
rising edge of clock state T3. During clock 
states T3 and T4 of an M1 cycle dynamic RAM 
refresh can occur while the CPU starts 
decoding and executing the instruction. When 
the Refresh Control signal becomes active, 
refreshing of dynamic memory can take place. 


Figure 5. Instruction Opcode Fetch 


2005-882 


CPU. 
Timing 
(Continued) 


~ Non-Maskable Interrupt Request Cycle. 


NMI is sampled at the same time as the 


’ maskable interrupt input INT but has higher 


priority and cannot be disabled under software 
control. The subsequent timing is similar to 


LAST M CYCLE ————_—_—» 
LAST YT TIME Af] 


Ao-A15 


MAEG 


RrsH 


* Although NMI is an asynchronous input, to guarantee its being 
recognized on the following machine cycle, NMI’s falling edge 


that of a normal memory read operation except 
that data put on the bus by the memory is 
ignored. The CPU instead executes a restart 
(RST) operation and jumps to the NMI service 
routine located at address O066H (Figure 9). 


>| @ —_ ® <—_— 
must occur no later t} -:. the rising edge of the clock cycle 
preceding TLAST. 


Figure 9. Non-Maskable Interrupt Request Op - ‘ion 


Bus Request/Acknowledge Cycle. The CPU 
samples*BUSREQ with the rising edge of the 
last clock period of any machine cycle (Figure 
10). If BUSREQ is active, the CPU sets its __ 
address, data, and MREQ, IORQ, RD, and WR 


CLOCK 


@- 

BUSREQ 

BUSACK 

Ao-Ais 
be = 

— 

MREQ 
mown = 

iona, 

wi 


@ \~- 


Watt 


NOTE: Ty = Last state of any M cycle. 


lines to a higk - :pedance state with the rising 
edge of the ne ‘ «:lock pulse. At that time, any 
external devicc- ..an take control of these lines, 
usually to transier data between memory and. 
I/O devices. 


FLOAT 


FLOAT 


UNCHANGED 


Tx = An arbitrary clock cycle used by requesting device. 


Figure 10. Bus Request/Acknowledge Cycle 
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CPU Halt Acknowledge Cycle. When the CPU 
Timing receives a HALT instruction, it executes NOP 
(Continued) _ states until either an INT or NMI input is 


received. When in the Halt state, the HALT 
output is active and remains so until an inter- 
rupt is processed (Figure 11). 


M1 —_——_—>|}——$ $A oamrot | m1 
% ty T2 T3 T, Ty T2 


CLOCK 


MALT 


Halt Instruction 
Received ° 


a 


NOTE: INT will also force a Halt exit. *See note, Figure 9. 


Figure 11. Halt Acknowledge Cycle 


Reset Cycle. RESET must be active for at least 
three clock cycles for the CPU to properly 
accept it. As long as RESET remains active, the 
address and data buses float, and the control 


inactive, two internal T cycles are consumed 
before the CPU resumes normal processing 
operation. RESET clears the PC register, so the 
first opcode fetch will be to location 0000 


outputs are inactive. Once RESET goes ~ (Figure 12). 
<i ---— 
TT T2 
cLock yy 
© 
FLOAT 
Ao-A1i5 ( 
FLOAT 
Do-D7 
> 
Mi 
iets LTT ‘ \ 
BUSACK 
HALT 


Figure 12. Reset Cycle 
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AC 
Charac- 
teristics 


38 TsBUSREQ(Cr) BUSREQ Setup Time to Clock ! 80 


*For clock periods other than the minimums shown in the table, 
calculate parameters using the expressions in the table on the 
following page. 


Z80 CPU 
oe Min Max 
Number Symbol Parameter (ns) (ns) 
1 TcC Clock Cycle Time 400* 
2 TwCh Clock Pulse Width (High) ; 180° 
3. TwCl Clock Pulse Width (Low) 180 2000 
4 TIC Clock Fall Time — 30 
5—TrC Clock Rise Time 30 
6 TdCr(A) Clock t to Address Valid Delay _— 145 
7  TdA(MREQf) Address Valid to MREQ 125* — 
| Delay 
8 TdCi(MREQf) Clock ! to MREQ ! Delay — 100 
9 TdCr(MREQr) Clock t to MREQ t Delay = 100 
10 — TwMREQh MREQ Pulse Width (High) 170° 
1] TwMREQ]1 MREO Pulse Width (Low) 360° — 
12  TdCf(MREQr) Clock ! to MREQ t Delay — 100 
13. TdCf(RDf) Clock | to RD | Delay — 130 
14 TdCr(RDr) Clock t to RD t Delay — 100 
15 —TsD(Cr) Data Setup Time to Clock 1 50 
16 ThD(RDr) Data Hold Time to RD 1 = 0 
17 TsWAIT(Cf) WAIT Setup Time to Clock | 70 — 
18  ThWAIT(Cf) WAIT Hold Time after Clock | — 0 
19 TdCr(M1f) Clock 1 to MI | Delay = 130 
20 —— TdCr(MI1r) Clock t to M1 1 Delay 130 
21 TdCr(RFSHf) Clock t to RFSH ! Delay — 180 
22 TdCr(RFSHr) Clock t to RFSH t Delay — 150 
23 TdCf(RDr) Clock | to RD t Delay — 110 
24  TdCr(RDf) Clock | to RD | Delay i — 100 
25 —— TsD(Cf) Data Setup to Clock | during 60 
M2, M3, My or Ms Cycles 
26 TdA(IORQf) Address Stable priortoIORQ ! 320° — 
27 TdCr(IORQf) Clock t to IORQ ! Delay — 90 
28 © TdCKIORQr) Clock | to IORO ! Delay _ 110 
29. © TdD(WRf) Data Stable prior to WR | 190* — 
30 —— TdCf(WRf) Clock ! to WR ! Delay 90 
31  TwWR WR Pulse Width 360* — 
32 TdCt(WRr) Clock | to WR t Delay _ 100 
33 TdD(WRf) Data Stable prior to WR ! 20* — 
34.  TdCr(WRbf) Clock t to WR } Delay — 80 
35 —TdWRr(D) Data Stable from WR t ——~~——— 120° 
36 TdCf(HALT) Clock } to HALT t or | — 300 
37. TwNMI NMI Pulse Width, g0. — 


Z80A CPU 
Min Max 
(ns) (ns) 
250* 
110° 
110 = =©2000 

— 30 

30 

— 110 

65° — 

— 85 

— 85 

110* 

-220*° — 
— 85 
— 95 
_— 85 
35 
_ 0 
70 _ 
—_ 0 
— 100 

100 

— 130 

— 120 

—_— 85 

— 85 

50 

180" — 

— 75 

_ 85 

80"  — 

80 

220* — 

— 80 

-l0* — 

— 65 

60* 

— 300 

80 _ 

50 — 


Z80B CPU 
Min Max 
(ns) (ns) 
165* 

65* 

65 2000 

— 20 

20 

_ 90 

35° — 

— 70 

_— 70 

65* 

135" — 

_— 70 

— 80 

— 70 

30 

— 0 

60 — 

— 0 

— 80 

80 

— 110 

— 100 

— 70 

— 70 

40 

110* — 

— 65 

— 70 

25" — 

70 

135" — 

— 70 

-55* 

— 60 

30* 

— 260 

70 _— 

50 — 
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AC 
Charac- 
teristics 
(Continued) 


Z80 CPU Z80A CPU Z80B CPU 
Min Max Min Max Min Max 
Number Symbol Parameter (ns) (ns) (ns) (ns) (ms) * (ns) 
39 ThBUSREQ(Cr) BUSREQ Hold Time after Clock! 0 © — oO — o> — 
40 —TdCr(BUSACKf#)-Clock 1 to BUSACK ! Delay —————— 120 100 90 
41 | TdCf(BUSACKr) Clock ! to BUSACK t Delay — 110 — 100 — 90 
42 TdCr(Dz) Clock | to Data Float Delay — 90 — 90 — 80 
43 TdCr(CTz) Clock | to Control Outputs Float — 110 — 80 _ 70 
Delay (MREQ, IORQ, RD, 
and WR) 
44 TdCr(Az) Clock t to Address Float Delay — 110 — 90 — 80 
45 —— TdCTr(A) Address Stable after MREQ |,——— 160* 80* —————_—— 35* -— 
IORQ t, RD t, and WR t 
46 TsRESET(Cr) — RESET to Clock t Setup Time 90 — 60 — 60 — 
47 ThRESET(Cr) RESET to Clock t Hold Time — 0 — 0 — 0 
48 TsINT{(Cr) INT to Clock ! Setup Time 80 _ 80 — 700 — 
49 ThINTr(Cr) INT to Clock | Hold Time _— 0 — 0 — 0 
50 — TdMIf(IOROQf)— M1 | to IOROQ | Delay ——-———— 920° 565° 365* —— 
51 — TdCf(IORQf) Clock | to IORQ | Delay — 110: — 8 — 70 
52 TdCi(IORQr) Clock t to IORO 1 Delay , — 100 _ 85 _ 70 
53 TdCf{(D) Clock | to Data Valid Delay — 230 _ 150 —_ 130 
*For clock periods other than the minimums shown in the table, 
calculate parameters using the following expressions. Calculated 
values above assumed TrC = TIC = 20 ns. 
Footnotes to AC Characteristics 
Number Symbol Z80 - Z80A Z80B 
TcC TwCh + TwCl + TrC + TiC TwCh.+ TwCl + TrC +T{C TwCh + TwCl + TrC + TiC 
2 TwCh Although static by design, Although static by design, Although static by design, 
TwCh of greater than 200 ps TwCh of greater than 200 ps TwCh of greater than 200 ys 
is not guaranteed is not guaranteed is not guaranteed 
7 — TdA(MREQ!)—TwCh + TiC - 75 —————— TwCh + TiC - 65 TwCh + TiC - 50 
10 TwMREQh TwCh + TiC - 30 TwCh + TfC - 20 TwCh + TiC - 20 
el TwMREQ1 TcC - 40 TcC - 30 TeC — 30 
26 TdA(IORQf) TcC - 80 TcC - 70 TcC - 55 
29 TdD(WRf) TcC - 210 TeC - 170 TcC - 140 
31 —— TwWR TeC - 40 —————— TcC - 30 TcC - 30 
33 TaD(WRf) TwCl + TrC — 180 TwCl + TrC — 140 TwCl + TrC - 140 
35 TdWRr(D) TwCl + TrC - 80 TwC] + TrC — 70 TwCl + TrC - 55 
45 TdCTr(A) TwCl + TrC — 40 TwCl + TrC — 50 TwCl] + TrC - 50 


50 TdM1{(IORQf) 


AC Test Conditions: 
Vin = 2.0 V 
Vir = 0.8V 
Vince = Voc -0.6 V 
Vitc = 0.45 V 


2TcC + TwCh + TiC - 80 2TcC + TwCh + TiC - 65 


VoH = 2.0V 
VoL = 0.8 V 
FLOAT = +0.5V 


2TcC + TwCh + TiC - 50 


APPENDIX F....FLOPPY ERROR CODE 


36 


Table 6 STATUS REGISTER SUMMARY 


ALL TYPE ! ‘READ — READ READ WRITE WRITE 
COMMANDS ADDRESS SECTOR TRACK SECTOR TRACK 
NOT READY NOT READY NOT READY NOT READY |NOT READY | NOT READY 


WRITE 0 WRITE WRITE 
PROTECT PROTECT PROTECT 


HEAD LOADED WRITE FAULT | WRITE FAULT 
RNF 0 
CRC ERROR 0 
LOST DATA LOST DATA 
DRQ DRQ 

BUSY BUSY 


S7 


RECORD TYPE 
RNF 

CRC ERROR 
.LOST DATA 
DRQ 
BUSY 


CRC ERROR 
LOST DATA 

DRQ. 
BUSY 


LOST DATA 
DRQ 
BUSY 


This bit when set indicates the drive is not ready. When reset it indicates that the drive 
is ready. This bit is an inverted copy. of the Ready input and logically ‘ored’ with MR. 
When set, indicates Write Protect is activated. This bit is an inverted copy of WRPT 
input. ; 


When set, the desired track was not verified. This bit is reset to 0 when updated. 


$3 CRC ERROR CRC encountered in ID field. 


When set, indicates Read/Write head is positioned to Track 0. This bit is an inverted 
copy of the TROO input. 


a When set, indicates index mark detected from drive. This bit is an inverted copy of the 
IP input. 


SO BUSY When set command is in progress. When reset no command is in progress. 


This bit when set indicates the drive is not ready. When reset, it indicates that the drive 
is ready. This bit is an inverted copy of the Ready input and ‘ored’ with MR. The Type Il 
and 11] Commands will not execute unless the drive is teady. 


1 = Deleted Data Mark. 0 = Data Mark. On any Write: It indicates a Write Fault. This bit 
is reset when updated. 

When set, it indicates that the desired track, sector, or side were not found. This bit is 
reset when updated. 

lf S4 is set, an error is found in one or more ID fields; otherwise it indicates error in 
data field. This bit is reset when updated. 


S1 DATA REQUEST |This bit is a copy of the DRQ output. When set, it indicates the DR is full on a Read 
Operation or the DR is empty on a Write operation. This bit is reset to zero when up- 
dated. 


SO BUSY When set, command is under execution. When reset, no command is under execution. 
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FD179XA-02 CERAMIC PACKAGE : FD179XB-02 PLASTIC PACKAGE 


This is a preliminary specification with tentative device parameters and may be subject to change after final product characterization is 


reserves the right to change said circuitry at anytime without notice. ‘ 
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WARRANTY NOTICE 


Advanced Digital Corporation now requires a Return Authorization 
Number for the return of any equipment for repair or credit. This 
number will be issued by the Customer Support Department. Any 
equipment received without the Return Authorization Number clearly 
marked on the outside of the package may be subject to significant 
delays in the repair process. 


Return Authorization Numbers are active for 30 days after they are 
issued. If the equipment specified in the Return Authorization is 
not received by Advanced Digital within this 30 day period signi- 
ficant delays in handling the repair may be incurred. 


If the equipment must be returned a second time, a new Return 
Authorization Number must be issued. Reuse of Return Authorization 
Numbers may result in delays in processing returns. 


Effective November 1, 1981, repair of all kit and nonwarranty 
boards will be $70.00. This fee is subject to change without 
notice. 


Returns for credit will be subject to a 15% restocking charge. If 
material for credit was purchased through a dealer, Advanced Digital 
cannot issue a credit. Adjustment must be handled through the dealer. 
Other credit returns should have reference to the original invoice 
number. 


If you have any questions regarding special handling, packaging of 


the equipment, or procedures for returning equipment, please contact 
the Advanced Digital Corporation. 


The warranty on the super quad is one year from the date of purchase. 


TECHNICAL APPLICATION NOTES FOR THE SUPER QUAD SINGLE BOARD COMPUTER. 


In case of problems with the SUPER QUAD; these are two thing a customer 

may do: 

1. send the product back for warranty service(turn around time is 1 day) 

2. follow thw following notes and then if there are still no results do 
the first step} 


1. I£ the board is totaly dead and won't communicate with the CRT, then 
do the following: 
a. check you power supply for 5,+,-12 volts. 
b. check pins 1,3,17 of the U53(BR1941) baud, rate gen. for step type 
pulses.(if you do not see any thing on these pins then replace the 
BR1941 chip) 


} cee © I dt Id 

c. Check your PS NET/I the Serial port adapter cable for seer phe: 
loss of + or - 12 volts or the 1488 chip. 

d. check pin 3 of U11(741s11). there should be a positive going 
Signal(about 5 volts) and when you press RESET you should see that 
pulse going to ZERO voltage. 

e. If the step d is OK then you have a problen vee either on of the 
a.°OF "D: OLr~ > « 

£. check the 4MHZ clock signal going to pin 6 of the CPU. 


2. 1f£ there is a problem with the floppy disk controller part only and 
you think that the phase lock loop needs to be adjusted, then follow 
the folowing steps: 


a. This is done with the help of a dual trace scope. 
b. put one channel on the 4MHZ signal(PIN 6 of the cpu chip) 
put the other channel on pin 7 of the U27(745124) and by tweeking 
the R26(pot) those two signals are supposed to lock. 
c. the above procedure is only recomended to engineeres or technicians 
with experience of doing such things before. 
3. Make sure the board is being properly cooled by a fan. 


4. The power consumption of the board is: 


+8v--- 1.8 amps max. 
+16--- .4 amps max. 
-16--- .2 amps max. 


5. To ensure the proper operation of your floppy disk drives, make 
sure to put the termination resistor at the end of the cable. 


6. Refer to the softare manual for software problems. 
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Application notes to run TURBO-DOS operating system: 
LE you have one of the early revisions of the SUPERQUAD check the following: 
1. pin 13 of the CTC should be hooked to +5V. 


2. R17 should be hooked to +5. 


WwW 
e 


for double sided drives, there should be a jumper from 33 connector 

to PIO bit3(PIO-29) 

4. 1E3 lin2 (PI0O-22) should goto ul8-9, on Some older rev. boards its 
also going to pin 12 of ul4. the place to cut would be on top of u8 
right above pin 20 there is a pad hole; the etch going north should be 
cut,then install a jumper from ul4-12 to ul5-6 
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application notes on how to interface the Measurement Systems Memory (DMB64086) 
<O the SUPERQUAD. 
ON DMB646@ SET SWITCHES AS FOLLOWS: 
(TOGLE SWITCH...UP MEANS PRESS TO THE TOP DOWN) 
Sl-1 DOWN,S1-2 DOWN.S1-3 DOWN, S1-4 DOWN 
S$2-1,2,4,5 Up------ S$3-1,2 UP----S4-1,4 DOWN----S5-1,2,3,4,5,6,8 UP 


HEADER 1 SHOULD BE WIRED AS: PIN 1 TO 16,3 TO 9,7 TO 11,8 TO 16. 


4l 


SUPER NET MODIFICATION SHEET 


To run the SUPER QuAd (Advanced Digital Corportion's S-199 single 
board computer) with the BSR 64/256 (PCE Systems’ 256K RAM card) there 
are two modifications to be made to.the SUPER Quad. The first 
modification (as described. below). is to. buffer the 2Z-8@ refresh 
signal, and bring it to pin .66 of. the S-190 bus (see figure 1). 


| U43 
1) Solder a wire from U5@, pin 28 | 


(Z-80) to U43, pin 14 (8T97). 2) 
Solder a wire from U43, pin 13 


(8T97) to pin 66 of the S-198 bus. 


The Second modification neéds to be © 
done so that the RAM card can sense 
when the 280 is in a wait state. 
This is done by cutting the RAM 
RFSH and FDC WAIT signals on the 
SUPER @yAbaway from the inputs of 
US6, and ANDING them and tying the 
result to PRDY of the S-198 bus 
(see figure 2). Because PRDY may be 
driven by a number of different 
cards, an open collector device is 
needed. For this purpose a 74809 is 
added to the board, as’ described 
below, at SPARE location U57. 


Figure 2 


1) Solder a 14 pin socket in location U57 for a 7489. 2) Solder a 

wire from RM6, pin 2 to U57, pin l. 3) Solder a wire from the plated 

through hole located under U55 between pins 13 & 14, to U57, pin 32. 
4) Solder a wire from U57, pin 3 to U56, 
pin 4. 5) Cut two traces located on 

es . RM6 

component side of board between U56 and 


RM6 (See Figure 3). 6) Install a 7489 in CUTS 


US7. U56 
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SUPER NET Parts list 


Item I Part Number I Location on board I Quantity 
~-------------- I----------------- 1 ---------------------] -------------- +--+. 
1. I 74LS06 I U-13 I 1 
2e I 743804 I U-6 I 1 
3. I 74LS04 I U-18,U-34 I 2 
4. I 7406 I U-32 I 1 
Se I 7497 I U-1 I 1 
6. I 74LS16 I U-41 I 1 
ig I 74811 I U-11 I 1 
8. I 74LS813 I U-47,U-56 I 2 
9. I 74LS14 _ I U-2 I 1 
16. I 74LS27 I U-35 I 1 
ll. I 74LS32 I U-42,U-22 I 2 
12. I 7438 I U-14 I 1 
13. I 74LS74 I U-33,U-48 I 2 
14. I 74LS123 I U-3,U-4 I 2 
15. I 748124 I U-27 I 1 
16. I 74LS132 I U-16,U-39,U-46 I 3 
TT. I 74LS138 I U-21,U-36 © I 2 
18. I 74LS139 I U-5 I 1 
19. I 74LS153 I U-28 I ) 
20. I 7408175 BE U-16 I 1 
21. I 74LS2406 I U-59,U-24 I 2 
22. tT 745248 I U-68,U-69 IT 2 
23%, I 7ALS244 I U-8 I 1 
24. I 74LS245 I U-44,U-51 I 2 
25% I 74LS273 I U-17 I 1 
25% I 745287 (PROM) I U-49 IT 1 
27. I 74LS373 I U-25,U-3@ I 2 
28. I 74LS374 I U-23 I l 
29. I 74LS393 I U-12,U-7 I 2 
36. I MB4164-28 I U-60 THRU U-67 I 8 
31. I Z-80A CPU I U-58 I 1 
32. I Z-80A PIO I U-9 I 1 
33. I Z-86A DART(SIO)I U-52 I 1 
34, I Z-8@A CTC I U-37 I 1 
35. I WD-1793(8877) I U-26 I 1 
36. I wbD-1691 I U-19 IT 1 
37. I wbd-2143 I U-20 I 1 
38. I BR-1941 I U-53 I l 
39. I TTLDM-106 I U-54 I 1 
40. I 2716 EPROM I U-29 I 1 
4l. I 81T97 I U-43 I l 
42. I 8T98 I U-55,U-15 I 2 
43. I 14 PIN HEADER I U-31 I 1 
44. I ~LM323K VOLT. I VR1 I 1 
45. I 8.860 MHZ XTAL I Yl 1 i 
46. I 5.806 MHZ XTAL I Y2 I 1 
47. lt 16 PIN SWITCH I SwWl I a 
48. I 2N2222 TRANS. I Q1,02,Q4 I 3 
49. I 2N39€66 TRANS. I Q3 I 1 
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228 MH CHOKE 
4.7K SIP 

16K SIP 

33 OHM SIP 
226/330 SIP 
33 OHM DIP 
1N914 DIODE 
5-1 V ZENER 
166 MF CAP 

-l MF CAP 

4.7 MF CAP 
19K POT 

14 PIN HEADER 
58 PIN HEADER 
46 PIN HEADER 
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CR2 I 
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I 

C6 ,C3,C18,C27,C281 

R27,R28 I 
"34,55 I 

J3 I 

J2 I 
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